Android学习笔记(三 数据库SQLITE的基本操作)
SQLITE是android自带的标准数据库,它支持SQL语句,是一个轻量级的嵌入式数据库.
学习SQLITE首先需要了解一些知识点:
1. SQLiteDatabase
?一个SQLiteDatabase的实例代表一个SQLite的数据库,通过SQLiteDatabase实例的一些方法,我们可以执行SQL语句,进行对数据库的增删改查操作。数据库对于一个应用来说是私有的,并且在一个应用当中,名字也是唯一的。
2. SQLiteOpenHelper
?这是一个抽象类。当在程序中调用这个类的方法getWritableDatebase()或者getReadableDatebase()方法的时候,如果当时没有数据,那么android系统就会自动生成一个数据库。对于SQLiteOpenHelper我们通常需要继承它,并实现它里面的3个函数
? (1)onCreate
?????在数据库第一次生成的时候会调用这个方法,一般我们在这个方法里边生成数据库表
??(2)onUpgrade
?????当数据库需要升级的时候,Android系统会自动调用这个方法,一般我们在这个方法里面删除数据库表,并建立新的数据库表。并且还可以根据应用需求进行其它操作。
? (3)onOpen
?????这是当打开数据库时的回调函数,一般也不会用到。
下面来展示一下操作数据库的具体代码
public class ActivityMain extends Activity {
?OnClickListener listener1 = null;
?OnClickListener listener2 = null;
?OnClickListener listener3 = null;
?OnClickListener listener4 = null;
?OnClickListener listener5 = null;
?Button button1;
?Button button2;
?Button button3;
?Button button4;
?Button button5;
?DatabaseHelper mOpenHelper;
?private static final String DATABASE_NAME ="dbForTest.db";
?private static final int DATABASE_VERSION =1;
?private static final String TABLE_NAME ="diary";
?private static final String TITLE ="title";
?private static final String BODY = "body";
?private static class DatabaseHelper extendsSQLiteOpenHelper {
??DatabaseHelper(Context context){
???super(context,DATABASE_NAME, null, DATABASE_VERSION);
??}
??@Override
??public voidonCreate(SQLiteDatabase db) {
???String sql= "CREATE TABLE " + TABLE_NAME + " (" + TITLE
?????+" text not null, " + BODY + " text not null " + ");";
???System.out.print(sql);
???Log.i("haiyang:createDB=",sql);
???db.execSQL(sql);
??}
??@Override
??public voidonUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){
??}
?}
?@Override
?public void onCreate(Bundle savedInstanceState){
??super.onCreate(savedInstanceState);
??setContentView(R.layout.main);
??prepareListener();
??initLayout();
??mOpenHelper = newDatabaseHelper(this);
?}
?private void initLayout() {
??button1 = (Button)findViewById(R.id.button1);
??button1.setOnClickListener(listener1);
??button2 = (Button)findViewById(R.id.button2);
??button2.setOnClickListener(listener2);
??button3 = (Button)findViewById(R.id.button3);
??button3.setOnClickListener(listener3);
??button4 = (Button)findViewById(R.id.button4);
??button4.setOnClickListener(listener4);
??button5 = (Button)findViewById(R.id.button5);
??button5.setOnClickListener(listener5);
?}
?private void prepareListener() {
??listener1 = newOnClickListener() {
???public voidonClick(View v) {
????CreateTable();
???}
??};
??listener2 = newOnClickListener() {
???public voidonClick(View v) {
????dropTable();
???}
??};
??listener3 = newOnClickListener() {
???public voidonClick(View v) {
????insertItem();
???}
??};
??listener4 = newOnClickListener() {
???public voidonClick(View v) {
????deleteItem();
???}
??};
??listener5 = newOnClickListener() {
???public voidonClick(View v) {
????showItems();
???}
??};
?}
?
?private void CreateTable() {
??SQLiteDatabase db =mOpenHelper.getWritableDatabase();
??String sql = "CREATE TABLE " +TABLE_NAME + " (" + TITLE
????+" text not null, " + BODY + " text not null " + ");";
??Log.i("haiyang:createDB=",sql);
??try {
???db.execSQL("DROPTABLE IF EXISTS diary");
???db.execSQL(sql);
???setTitle("数据表成功重建");
??} catch (SQLException e){
???setTitle("数据表重建错误");
??}
?}
?
?private void dropTable() {
??SQLiteDatabase db =mOpenHelper.getWritableDatabase();
??String sql = "drop table " +TABLE_NAME;
??try {
???db.execSQL(sql);
???setTitle("数据表成功删除:"+ sql);
??} catch (SQLException e){
???setTitle("数据表删除错误");
??}
?}
?
?private void insertItem() {
??SQLiteDatabase db =mOpenHelper.getWritableDatabase();
??String sql1 = "insert into " +TABLE_NAME + " (" + TITLE + ", " + BODY
????+") values('haiyang', 'android的发展真是迅速啊');";
??String sql2 = "insert into " +TABLE_NAME + " (" + TITLE + ", " + BODY
????+") values('icesky', 'android的发展真是迅速啊');";
??try {
???Log.i("haiyang:sql1=",sql1);
???Log.i("haiyang:sql2=",sql2);
???db.execSQL(sql1);
???db.execSQL(sql2);
???setTitle("插入两条数据成功");
??} catch (SQLException e){
???setTitle("插入两条数据失败");
??}
?}
?
?private void deleteItem() {
??try {
???SQLiteDatabasedb = mOpenHelper.getWritableDatabase();
???db.delete(TABLE_NAME," title = 'haiyang'", null);
???setTitle("删除title为haiyang的一条记录");
??} catch (SQLException e) {
??}
?}
?
?private void showItems() {
??SQLiteDatabase db =mOpenHelper.getReadableDatabase();
??String col[] = { TITLE, BODY};
??Cursor cur =db.query(TABLE_NAME, col, null, null, null, null, null);
??Integer num =cur.getCount();
??setTitle(Integer.toString(num)+ " 条记录");
?}
}
在上述代码中
?DataBaseHelper类继承了SQLieOpenHelper类,并且重写了onCreate和onUpgrade方法。
?在onCreate方法中我们首先构造了一条SQL语句,然后调用了db.execSQL(sql)执行SQL语句。生成了一个表
?因为目前我们还不需要升级数据库,所以我们在onUpgrade()函数里面没有执行任何操作。
==============================================================================================
下面对应的就是增删改查方法
主要说下查的方法:
?如前面知识点所说,先创建一个SQLiteDatebase的对象,得到一个可写的数据库.
?Sring col[]={TITLE,BODY};
?SQLiteDatabase db =mOpenHelper.getReadableDatabase();
?Cursor cur = db.query(TABLE_NAME, col, null,null, null, null, null);
?这条语句将查询到的数据放到一个Cursor中。这个Cursor中封装了这个数据表TABLE_NAME当中的所有条列。下面具体说下query()方法:
?第一个参数是数据库里边表的名字。
?第二个参数是我们想要返回数据包含的列的信息。如上面代码所示我们把列名存放在名为col的数组里
?第三个参数为selection,相当于SQL语句的where部分,如果想返回所有的数据,那么就直接设置为null.
?第四个参数为selectionArgs.在selection部分,有可能用到"?",那么在selectionArgs定义的字符串会代替selection中的"?".
?第五个参数为groupBy。定义查询出来的数据是否分组,如果为null,则说明不需要分组。
?第六个参数为having。相当于SQL语句当中的having部分。
?第七个参数为orderBy。这个就是排序。
最后 Integernum=cur.getCount()语句通过getCount()方法,可以得到Cursor当中数据的个数。
对于Cursor的理解:
Cursor本身是指针的意思。在android中是一个非常有用的接口,通过Cursor我们可以对从数据库查询出来的结果集进行随机的读写访问。
?
一个简单的对数据库操作的demo介绍完了,最后需要说明的是在Android的设计哲学里鼓励开发者使用内部类,这样不但使用方便,而且执行效率也高。