Android中的数据存取 之 SQLite


1.Android中通过SQLite数据库引擎来实现结构化数据存储。SQLite是一个嵌入式数据库引擎,针对内存等资源有限的设备,提供的是一种高效的数据库引擎。

2.Android提供了创建和使用SQLite数据库的API。SQLiteDatabase代表一个数据库对象,提供了操作数据库的一些方法,另外还有一个SQLiteOpenHelper工具类提供更简洁的功能。

3. SQLiteOpenHelper是SQliteDatabase的一个帮助类,用来管理数据库的创建和版本更新。一般用法是定义一个类继承之,并实现两个抽象方法onCreate(SQLiteDatabase db)和onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion)类创建和跟新数据库。

Android中操作数据库首先要通过一个 类:android.database.sqlite.SQLiteOpenHelper。它封装了如何打开一个数据库,其中当然也包含如果数据库不存在 就创建这样的逻辑。

SQLiteOpenHelper 类

其中:

getReadableDatabase()得到可读的数据库,返回SQLiteDatabase对象,然后通过对象进行数据库操作。

getWritableDatabase()得到可写的数据库,返回SQLiteDatabase对象,然后通过对象进行数据库操作。

onCreate(SQLiteDatabase db)在第一次创建数据库时调用。

onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)在更改数据库时都会调用。

onOpen(SQLiteDatabase db)当数据库打开时调用。

close()关闭数据库。

看一个例子:

  1. public class SqlLiteHelper extends SQLiteOpenHelper {  
  2.   
  3.     public class DatabaseHelper extends SQLiteOpenHelper {    
  4.         
  5.         private static final int VERSION = 1;    
  6.         
  7.   
  8.         public DatabaseHelper(Context context, String name, CursorFactory factory,    
  9.                 int version) {    
  10.             super(context, name, factory, version);    
  11.         }    
  12.         
  13.         @Override    
  14.         public void onCreate(SQLiteDatabase db) {    
  15.             System.out.println("create a Database");    
  16.             db.execSQL("create table user(id int,name varchar(20))");    
  17.         }    
  18.         
  19.         @Override    
  20.         public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {    
  21.             System.out.println("update a Database");    
  22.             db.execSQL("DROP TABLE IF EXISTS user");  
  23.         }    
  24.         
  25.     }    
  26.   
  27. }

这里面,如下的语句需要解释:

super(context, DATABASE_NAME, null, DATABASE_VERSION)

数据库连接的初始化,中间的那个null,是一个CursorFactory参数,没有仔细研究这个参数,暂时置空吧。

public void onCreate(SQLiteDatabase db)

这里面的onCreate是指数据库onCreate时,而不是DatabaseHelper的onCreate。也就是说,如果已经指定 database已经存在,那么在重新运行程序的时候,就不会执行这个方法了。要不然,岂不是每次重新启动程序都要重新创建一次数据库了!在这个方法中,完成了数据库的创建工作。也就是那个execSQL()方法。

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)

在程序的开发维护过程中,数据库的结构可能会有变化,那么这个方法就有用处了。在DatabaseHelper这个对象一创建时,就已经把参数 DATABASE_VERSION传入,这样,如果Android发现此版本与现有版本不一致,就会调用这个onUpgrate方法。于是,可以在这里面实现一些数据的upgrade工作,比如说创建一个临时表,将数据由临时表中转到新的表结构中。需要注意的是,这里面的onUpgrade是在版本不一致时调用,也就是说不管当前需要的版本高于现有版本还是低于现有版本,都会出发这个方法,类似的这种情况,就需要对oldVersion和 newVersion进行判断之后再决定使用什么策略来更新数据。

  • 1
  • 2
  • 下一页

相关内容