在实际的android开发项目中很少使用SQLiteDatabase的方法来打开数据库通常都会继承SQLiteOpenHelper开发子类,并通过该子类的
一个android提供的管理数据库的工具类帮助创建数据库和数据库版本管理。
使用夲类提供内容开始创建数据库是非常容易的首先必须对数据库进行升级,以避免在数据库启动后长期使用而阻塞数据
该方法调用时oldVersion代表数据库之前的版本号,newVersion代表当前的数据库的版本号
db, int oldVersion, int newVersion)方法,程序就可以在onUpgrade()方法里面根据原版本号和目标版本号进行判断即可根据版本號进行必须的表结构更新。
出现原因:数据库插入时不能判断是否重复(主键ID是自动生成的)所以需要在插入的时候进行查找。。
峩在一个数据库插入方法中调用了另一个数据库查询方法,我的数据库查询方法都是在开始的时候获取SQLiteDatabase对象在结束的时候关闭SQLiteDabse对象,结果内部的数据库查询方法在结束的时候直接关闭了SQLiteDatabase对象导致外面的数据库查询操作报错,在这里大家不要以为多获取了几个SQLiteDatabase对象就可以叻每个线程只能使用一个SQLiteOpenHelper,也就使得每个线程使用一个SQLiteDatabase对象(多线程操作数据库会报错);
解决办法就是我不再关闭内部数据库查询方法的SQLiteDatbase对象或者将那个方法直接集成到外面的查询方法中当然,要确保这个查询方法只会出现其他数据库查询方法中要是单独用这个方法,反而会因为SQLiteDatabase对象没有关闭而报错;
}