设为首页 加入收藏

TOP

Android中的数据存取 之 SQLite
2014-11-24 13:22:19 来源: 作者: 【 】 浏览:1
Tags:Android 数据 存取 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()关闭数据库。


看一个例子:


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


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进行判断之后再决定使用什么策略来更新数据。


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇JAVA IO操作总结——节点流和处理.. 下一篇Android中的数据存取 之 File

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: