设为首页 收藏本站
查看: 1238|回复: 0

[经验分享] SQLite 存储

[复制链接]

尚未签到

发表于 2016-11-28 11:02:19 | 显示全部楼层 |阅读模式
SQLite是一种轻量级的,嵌入式的数据库系统,它占用的资源非常低。SQLite通过文件来保存数据库与,一个文件就是一个数据库。
  


Android平台下数据库相关类

◆SQLiteOpenHelper 抽象类:通过从此类继承实现用户类,来提供数据库打开、关闭等操作函数。
◆SQLiteDatabase 数据库访问类:执行对数据库的插入记录、查询记录等操作。
◆SQLiteCursor 查询结构操作类:用来访问查询结果中的记录。
 


  • SQLiteOpenHelper抽象类

 

package com.test.sqlitedemo;
import android.R.integer;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.DropBoxManager;
import android.provider.Contacts.Intents.Insert;
import android.text.style.SuperscriptSpan;
import android.widget.TableLayout;
public class dbHelper extends SQLiteOpenHelper
{
private static String dbname = "data.db";  
private static int version = 1;  
//构造方法1(一般用方法1比较好,应为数据库名字和版本不会改变)
public dbHelper(Context context)
{
super(context, dbname, null, version);
}
//构造方法2
public dbHelper(Context context,String name,CursorFactory cursorFactory,int version)
{
//调用父类的构造方法
super(context, name, cursorFactory, version);
}
@Override
public void onCreate(SQLiteDatabase db)
{
// 创建数据库后,对数据库的操作(比如建表)
db.execSQL("CREATE TABLE IF NOT EXISTS person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age INTEGER)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
{
// 更新数据库版本的操作
db.execSQL("DROP TABLE IF EXISTS person");  
onCreate(db);
}
}

 SQLiteOpenHelper主要的三个方法是:
①构造方法:

public dbHelper(Context context){}


public dbHelper(Context context,String name,CursorFactory cursorFactory,int version){}

其中,context是上下文环境,一般是Activity;name是数据库名字;cursorFactory是游标工程,一般为null;version是指现在数据库版本,由自己指定。
②onCreate(){}方法

public void onCreate(SQLiteDatabase db){}  
这个方法在数据库第一次创建的时候调用,一般是做一些数据库的初始化工作,比如建表。
这个方法的参数是一个SQLiteDatabase数据库,建表之类的工作,就是通过调用db.execSQL()完成。
③onUpgrade(){}

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){}
 
这个方法在更新数据库的时候调用,进行的是一些更新的操作。
 
 


  • SQLiteDatabase 数据库的使用:

要获取SQLiteDatebase对象,可以使用

SQLiteDatabase db = databaseHelper.getWritableDatabase();
 或者

SQLiteDatabase db = databaseHelper.getReaderableDatabase();
 二者的区别是:在数据库是可读写时,无异;当数据库是只读时,前者会抛出异常。
 
获取了db对象后,利用execSQL()方法,就可以对数据库进行增删改查操作了。
例如:

       db.execSQL("DROP TABLE IF EXISTS person");        
db.execSQL("CREATE TABLE person(id INTEGER PRIMARY KEY AUTOINCREMENT,name VARCHAR(20), age INTEGER)");
 可以使用DDL语言。
对于不熟悉SQL语言的程序员,也可以使用SQLiteDatebase提供的方法:
db.query(),db.insert(),db.update(),db.delete()
这些方法会和哈希键--值对ContentValues一起用到,例如:

        ContentValues contentValues = new ContentValues();  
contentValues.put("name", person.getName());  
contentValues.put("age", person.getAge());  
database.insert("person", null, contentValues);  
  




  • Cursor的使用:

通过db.rawQuery()返回的查询结果,可以用Cursor来指向他们。
Cursor指向的是返回结果的第1个记录的前面一个节点,所以要获取操作第一个记录,需要     Cursor.moveToNext()。
例如:

        String args[]={et_id.getText().toString()};
Cursor cursor=db.rawQuery("select name,age from student where id=?",args);
if(cursor.moveToNext())
{
et_name.setText(cursor.getString(cursor.getColumnIndex("name")));
et_age.setText(cursor.getString(cursor.getColumnIndex("age")));
Toast.makeText(MainActivity.this, "查詢成功", Toast.LENGTH_LONG).show();
}
 
下面的代码示出Acitivity里面,如何使用这些SQLite

package com.test.sqlitedemo;
import android.R.integer;
import android.R.string;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.content.DialogInterface.OnClickListener;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import android.support.v4.app.NavUtils;
public class MainActivity extends Activity {
private Button btn_selcet,btn_insert,btn_update,btn_delete;
private EditText et_id,et_name,et_age;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);      

btn_selcet=(Button)findViewById(R.id.btn_select);
btn_insert=(Button)findViewById(R.id.btn_insert);
btn_update=(Button)findViewById(R.id.btn_update);
btn_delete=(Button)findViewById(R.id.btn_delete);
et_id=(EditText)findViewById(R.id.et_id);
et_name=(EditText)findViewById(R.id.et_name);
et_age=(EditText)findViewById(R.id.et_age);
btn_selcet.setOnClickListener(listener);   
btn_insert.setOnClickListener(listener);
btn_update.setOnClickListener(listener);   
btn_delete.setOnClickListener(listener);   
}
View.OnClickListener listener=new View.OnClickListener()
{
@Override
public void onClick(View v)
{
// 獲取SQLiteDatabase實例db,然後對各個事件調用db的不同操作
DBHelper dbHelper=new DBHelper(MainActivity.this);
SQLiteDatabase db=dbHelper.getWritableDatabase();
switch (v.getId())
{
case R.id.btn_select://查詢
if(et_id.getText().toString()!=null)
{
String args[]={et_id.getText().toString()};
Cursor cursor=db.rawQuery("select name,age from student where id=?",args);
if(cursor.moveToNext())
{
et_name.setText(cursor.getString(cursor.getColumnIndex("name")));
et_age.setText(cursor.getString(cursor.getColumnIndex("age")));
Toast.makeText(MainActivity.this, "查詢成功", Toast.LENGTH_LONG).show();
}
}
else
{
Toast.makeText(MainActivity.this, "查詢ID不能為空", Toast.LENGTH_LONG).show();
}
break;
case R.id.btn_insert://添加
if (et_id.getText().toString()!=null)
{     
db.execSQL("insert into student(id,name,age) values(?,?,?)",new String[]{et_id.getText().toString(),et_name.getText().toString(),et_age.getText().toString()});
Toast.makeText(MainActivity.this, "添加"+et_id.getText().toString()+"成功", Toast.LENGTH_LONG).show();
} else
{
Toast.makeText(MainActivity.this, "插入ID不能為空", Toast.LENGTH_LONG).show();
}
break;
case R.id.btn_update://更新
db.execSQL("update student set name=?,age=? where id=?",new String[]{et_name.getText().toString(),et_age.getText().toString(),et_id.getText().toString()});
Toast.makeText(MainActivity.this, "更新成功", Toast.LENGTH_LONG).show();
break;
case R.id.btn_delete://刪除
db.execSQL("delete from student where id=?",new String[]{et_id.getText().toString()});            
et_id.setText("");
et_name.setText("");
et_age.setText("");
Toast.makeText(MainActivity.this, "刪除成功", Toast.LENGTH_LONG).show();
break;
default:
break;
}
}
};
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}

}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-306632-1-1.html 上篇帖子: SQLITE使用 下篇帖子: SQLite 错误码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表