Android SQLiteOpenHelper 重复执行OnCreate()
说明:
android中首次调用getWritableDatabase或getReadableDatabase执行OnCreate()方法,当数据库中不存在该表时执行创建操作
建议:
建议创建表时在sql中添加判断语句 "CREATE TABLE IF NOT EXISTS “
问题描述:
1.数据库中相关表已经创建
2.表中已经添加数据
当查找表中总数的时候总是为空...
解决问题:
1.跟踪log发现每次查询都会重新执行OnCreate()被执行并且sql中IF NOT EXISTS 无效,最后发现:
getWritableDatabase执行了查询操作.
最近新加需求所以要添加一张表;逻辑和代码都按照以前能正常使用的写(就差没复制了),结果在运行的时候报了一个没有表的异常。纠结了很久,后来没办法理了下思路,表没创建成功,应该是没执行建表的语句,一打印log,果然是的。然后我手动调用onCreate(SQLiteDatabase db)居然就没出问题了。所以才有个这个onCreate(SQLiteDatabase db)调用时机的疑惑。
SQliteOpenHelper是一个辅助类,主要用来管理数据库的创建和版本的管理。说onCreate的使用时机,就不能孤立另外的2个方法:onUpgrade,onOpen.
参照sdk中的demo(记事本),大概是以下的使用场景:
onCreate(SQLiteDatabase):在数据库第一次生产的时候会调用这个方法,一般我们在这个方法里边生产数据库表。
onUpgrade(SQLiteDatabase,int,int):当数据库需要升级的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据库表,并建立新的数据库表,当然是否还需要做其他的操作,完全取决于应用程序的需求。
onOpen(SQLiteDatabase):这是当打开数据库时的回调函数,一般也不会用到。
这个很容易理解,在数据库第一次被创建时调用onCreate函数,参看帮助文档对这个函数的说明:Called when the database is created for the first time.也就是说在第一次创建数据库时调用,而数据库被创建出来后这个函数就没有用了,系统将不会再调用它,如果你想给数据库中加入一个表,那么可以使用onUPgrade函数,或者像你所做的那样,手动来调用onCreate函数。
-----------------******注******------------------------
注:实际情况中,我们总是通过一个类继承SQLiteOpenHelper来使用SQLite数据库,那么什么时候会调用onCreate函数呢?当我们产生这个类的对象的时候是不会调用onCreate函数的,只有第一次通过这个对象调用getReadableDatabase或者getWritableDatabase函数时才会调用onCreate函数,而如果调用过一次这个对象的getReadableDatabase或者getWritableDatabase函数后系统将不会再调用onCreate函数。
你们说的和我以前想的都没错,刚才我验证了:onCreate(SQLiteDatabase db)方法当且仅当数据库第一次创建的时候执行。如果想在已有的数据库上新增一张新表,只在onCreate(SQLiteDatabase db)方法中增加一条sql语句和修改版本号是不够的,还要在onUpgrade()函数中在调用一次OnCreate()函数。
- public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
- // TODO Auto-generated method stub
- try {
- db.execSQL("drop table if exists "+mTableName);
- onCreate(db);
- } catch (SQLException e) {
- e.printStackTrace();
- }
- }
转载地址:http://blog.csdn.net/myas0735/article/details/8127454