Sqlite创建数据库时不走onCreate 和onUpgrade 方法的问题解决

Sqlite数据库, 相信大家在平时的项目开发中都比较常用. 这次在自己项目实践过程中却遇到了一个问题:

按照标准的Sqlite数据库操作流程,在MySqliteOpenHelper类的onCreate() 方法中,写了建表语句,但一运行后发现只创建了数据库文件,里面并没有建好表,在调用dao类的增删改查方法后会报这么一个错误,找不到相应的表,如图所示:

我下意识地检查了建表语句,发现也没问题呀,折腾的不行,又把代码单独抽离出来,发现能建表成功呀!真是奇怪,用了这么多Sqlite数据库还是第一次遇到这么奇葩的问题,后面实在不行,直接用小虫子断点调试,发现根本就没有走onCreate()方法,建表语句根本没有执行,能创建表出来,才见鬼了呢!!! 

后面发现在自己的工程项目中,已经有创建类继承SqliteOpenHelper,在里面有执行其它的建表操作了. 而自己再创建类继承SqliteOpenHelper , 创建数据库建表时,就会出现这种奇怪问题!! 原因大家都应该知道,系统在初始化的时候只会执行一次onCreate方法,今后将不再执行,后续的升级操作,只能在onUpgrade中执行.

这里还涉及到另外一个问题,即Sqlite能否创建多个数据库,刚才自己的操作也算间接实践了一下,是可以创建,但表却建不出来...

解决方法: 很简单,那就是一个项目当中只创建一个数据库呗,根据实际需求可创建多个表,这样的话,上面的问题就解决了....

注意: 建表的sql语句很容易出现,所以大家在这里要多注意,仔细检查一下!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值