详解Android轻量型数据库SQLite
数据库是Android存储方案的核心,在Andorid中SQLite非常轻量,而且执行sql语句甚至比MySQL还要快。
SQLiteDatabase是Android中操作数据库的核心类之一,使用SQLiteDatabase可以打开数据库,也可以对数据库进行操作,然而,为了数据库升级以及使用更加方便,我们常用SQLiteOpenHelper的子类来完成创建,打开数据库的操作。
SQLiteOpenHelper是一个抽象类,在该类中有下面两个必须实现的方法:
publicvoidonCreate(SQLiteDatabasedb);//该函数在数据库第一次被建立时调用 publicvoidonUpgrade(SQLiteDatabasedb,intoldVersion,intnewVersion);//数据库更新升级操作
我们新建一个类DBHelperextendsSQLiteOpenHelper
importjava.util.Random;
importandroid.R.bool;
importandroid.content.Context;
importandroid.database.Cursor;
importandroid.database.sqlite.SQLiteDatabase;
importandroid.database.sqlite.SQLiteDatabase.CursorFactory;
importandroid.database.sqlite.SQLiteOpenHelper;
publicclassDBHelperextendsSQLiteOpenHelper{
//设置数据库默认版本
privatestaticfinalintVERSON=1;
//自定义数据库名,可以随便取名字
privatestaticfinalStringDBNAME="mydb";
//继承SQLiteOpenHelper类的类必须有自己的构造函数
//该构造函数4个参数,直接调用父类的构造函数。其中第一个参数为该类本身;第二个参数为数据库的名字;
publicDBHelper(Contextcontext,Stringname,CursorFactoryfactory,
intversion){
super(context,name,factory,version);
}
//该构造函数有3个参数,因为它把上面函数的第3个参数固定为null了
publicDBHelper(Contextcontext,Stringname,intverson){
this(context,name,null,verson);
}
//该构造函数只有2个参数,在上面函数的基础上将版本号固定了
publicDBHelper(Contextcontext,Stringname){
this(context,name,VERSON);
}
//该构造函数只有1个参数,固定默认数据库,在这里我们实现增删改查为了方便,就用它了
publicDBHelper(Contextcontext){
this(context,DBNAME,null,VERSON);
}
//该函数在数据库第一次被建立时调用
publicvoidonCreate(SQLiteDatabasedb){
System.out.println("createasqlitedatabase");
//建表语句(注意:因为在绑定数据时,Cursor对象返回的记录集中必须包含一个"_id"字段,否则无法完成数据绑定
Stringsql="CREATETABLE[test]("+
"[_id]AUTOINC,"+
"[name]varchar(20),"+
"[age]varchar(20),"+
"PRIMARYKEY([_id]))";
db.execSQL(sql);
//向test表中插入10条数据
for(inti=1;i<=10;i++){
Stringname="Jepson";
name+=i;
Stringage="age";
age+=i;
db.execSQL("insertintotest(name,age)values(?,?)",newObject[]{name,age});
}
}
//数据库更新操作
publicvoidonUpgrade(SQLiteDatabasearg0,intarg1,intarg2){
System.out.println("updateasqlitedatabase");
}
//自定义query方法,用以执行查询语句,返回Cursor对象
publicCursorquery(Stringsql,String[]args){
//调用getReadableDatabase方法时,如果数据库文件不存在,会调用onCreate方法
SQLiteDatabasedb=this.getReadableDatabase();
Cursorcursor=db.rawQuery(sql,args);
returncursor;
}
}
这样,我们的DBHelper类写好了,我们来实现一个查询操作。
第一步,activity_main.xml添加listview展示控件
activity_main.xml
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#FFFFFF" android:orientation="vertical" tools:context=".MainActivity"> <ListView android:id="@android:id/list" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_weight="1" android:divider="#6b6f74" android:dividerHeight="1px"> </ListView> </LinearLayout>
第二步,新建一个xml布局文件,用来作为列表项使用的布局资源
user_list_cell.xml
<?xmlversion="1.0"encoding="utf-8"?> <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="#FFFFFF"> <!--大字体TextView,用以展示name姓名--> <TextView android:id="@+id/tvName" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Large" android:textColor="#000000" android:textSize="20dp"/> <!--小字体TextView,用以展示age年龄--> <TextView android:id="@+id/tvAge" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Small" android:textColor="#000000" android:textSize="14dp"/> </LinearLayout>
第三步,主Activity
importandroid.os.Bundle;
importandroid.app.Activity;
importandroid.app.ListActivity;
importandroid.database.Cursor;
importandroid.support.v4.widget.SimpleCursorAdapter;
importandroid.view.Menu;
importandroid.widget.Toast;
publicclassMainActivityextendsListActivity{
protectedvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
publicvoidinitView(){
//调用只有1个参数的构造函数,实例化dbHelper
DBHelperdbHelper=newDBHelper(this);
//新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
Cursorcursor=dbHelper.query("select*fromtest",null);
//创建SimpleCursorAdapter对象,5个参数,
//第一个是context,就写当前this就行
//第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
//第三个就是Cursor对象
//第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
//第五个就是对应列表项布局中的控件ID了
SimpleCursorAdaptersimpleCursorAdapter=newSimpleCursorAdapter(this,
R.layout.user_list_cell,cursor,
newString[]{"name","age"},newint[]{R.id.tvName,
R.id.tvAge});
setListAdapter(simpleCursorAdapter);
Toast.makeText(this,"查询成功",Toast.LENGTH_SHORT).show();
}
}
执行一下看看,我们是不是查询成功了?
操作SQLite数据库应了解,对数据库的增删改查都有两种方法,一种是前面的使用rawQuery方法直接执行SQL语句,另一种就是使用SQLiteDatabase类的相应方法来操作,下面举一个第二种的例子,比如我们要插入数据name=11age=22
importandroid.os.Bundle;
importandroid.app.Activity;
importandroid.app.ListActivity;
importandroid.database.Cursor;
importandroid.support.v4.widget.SimpleCursorAdapter;
importandroid.view.Menu;
importandroid.widget.Toast;
publicclassMainActivityextendsListActivity{
protectedvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
publicvoidinitView(){
//执行添加操作
DBHelperdbHelper=newDBHelper(this);
//获得写入权限getWritableDatabase
SQLiteDatabasedb=dbHelper.getWritableDatabase();
//新建contentvalues保存insert数据
ContentValuescv=newContentValues();
cv.put("name","11");
cv.put("age","22");
db.insert("test",null,cv);
Toast.makeText(this,"添加成功",Toast.LENGTH_SHORT).show();
////查询操作
////调用只有1个参数的构造函数,实例化dbHelper
//DBHelperdbHelper=newDBHelper(this);
////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
//Cursorcursor=dbHelper.query("select*fromtest",null);
////创建SimpleCursorAdapter对象,5个参数,
////第一个是context,就写当前this就行
////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
////第三个就是Cursor对象
////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
////第五个就是对应列表项布局中的控件ID了
//SimpleCursorAdaptersimpleCursorAdapter=newSimpleCursorAdapter(this,
//R.layout.user_list_cell,cursor,
//newString[]{"name","age"},newint[]{R.id.tvName,
//R.id.tvAge});
//setListAdapter(simpleCursorAdapter);
//Toast.makeText(this,"查询成功",Toast.LENGTH_SHORT).show();
}
}
执行插入成功以后,再将插入语句注释,将查询语句去掉注释,重新启动,会发现最后一多了一个item,添加成功。
另外查询记录获得的Cursor对象,需要使用movetoFirst,moveToNext,movToPosition(position)等方法将指针移动相应的位置,来进行查询结果的读取。
importandroid.os.Bundle;
importandroid.app.Activity;
importandroid.app.ListActivity;
importandroid.database.Cursor;
importandroid.support.v4.widget.SimpleCursorAdapter;
importandroid.view.Menu;
importandroid.widget.Toast;
publicclassMainActivityextendsListActivity{
protectedvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
publicvoidinitView(){
//解析Cursor对象的查询操作
DBHelperdbHelper=newDBHelper(this);
SQLiteDatabasedb=dbHelper.getWritableDatabase();
Cursorcursor=db.query("test",null,null,null,null,null,null,
null);
//定义结果字符串
Stringresult="";
//判断cursor不为空这个很重要
if(cursor!=null){
while(cursor.moveToNext()){
Stringname=cursor.getString(cursor.getColumnIndex("name"));//获取name列的值
Stringage=cursor.getString(cursor.getColumnIndex("age"));//获取age列的值
result+="姓名:"+name+",年龄:"+age+"\n";
}
}
cursor.close();
db.close();
System.out.println(result);
Toast.makeText(this,result,Toast.LENGTH_SHORT).show();
////执行添加操作
//DBHelperdbHelper=newDBHelper(this);
////获得写入权限getWritableDatabase
//SQLiteDatabasedb=dbHelper.getWritableDatabase();
////新建contentvalues保存insert数据
//ContentValuescv=newContentValues();
//cv.put("name","11");
//cv.put("age","22");
//db.insert("test",null,cv);
//Toast.makeText(this,"添加成功",Toast.LENGTH_SHORT).show();
////查询操作
////调用只有1个参数的构造函数,实例化dbHelper
//DBHelperdbHelper=newDBHelper(this);
////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
//Cursorcursor=dbHelper.query("select*fromtest",null);
////创建SimpleCursorAdapter对象,5个参数,
////第一个是context,就写当前this就行
////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
////第三个就是Cursor对象
////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
////第五个就是对应列表项布局中的控件ID了
//SimpleCursorAdaptersimpleCursorAdapter=newSimpleCursorAdapter(this,
//R.layout.user_list_cell,cursor,
//newString[]{"name","age"},newint[]{R.id.tvName,
//R.id.tvAge});
//setListAdapter(simpleCursorAdapter);
//Toast.makeText(this,"查询成功",Toast.LENGTH_SHORT).show();
}
}
执行以后,可以发现,name和age全都获取到了,并显示在了Toast和system.out中。是不是很有意思呢?
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。