关于SQLiteOpenHelper的onCreate(SQLiteDatabase db)方法调用时机的疑惑
2013-02-26 09:51
471 查看
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()函数。
说明:
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(); } } 转载地址:/article/9150098.html
相关文章推荐
- 关于SQLiteOpenHelper的onCreate(SQLiteDatabase db)方法调用时机的疑惑
- 关于SQLiteOpenHelper的onCreate(SQLiteDatabase db)方法调用时机的疑惑
- [android]关于SQLiteOpenHelper的onCreate(SQLiteDatabase db)方法调用时机
- SQLiteOpenHelper 用单例模式实现后 onCreate 方法不执行的解决过程
- SqliteDatabase之SqliteOpenHelper_封装方法
- Context与SQLiteDatabase的方法openOrCreateDatabase的区别 (context、SQLiteOpenHelper)
- Context与SQLiteDatabase的方法openOrCreateDatabase的区别 (context、SQLiteOpenHelper)
- 关于QT5 SQLITE中QSqlQuery::exec: database not open的问题的解决方法
- Sqlite中DbOpenHelper的onCreate方法不能被调用
- Android SQLiteOpenHelper 实例方法getReadableDatabase()和getWritableDatabase() 区别
- SQLiteOpenHelper的getReadableDatabase()和getWritableDatabase()方法理解灵感
- SQLiteOpenHelper 中什么时候调用 onCreate() , 什么时候调用 onUpgrade() ?
- SQLiteDatabase的openOrCreateDatabase方法的返回类型为null
- android SQLiteOpenHelper的使用方法
- at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:224)
- SQLiteDatabase跟SQLiteOpenHelper
- SQLiteOpenHelper/SQLiteDatabase/Cursor源码解析
- sqliteopenhelper继承类的oncreate函数调用时间
- PHP PDO sqlite ,Unable to Open database file的解决方法
- Sqlite创建database的两种方法,以及源码分析,以及抽象类如何在SqliteHelper中应用