首页 > 代码库 > Android Exception 7(attempt to re-open an already-closed object )

Android Exception 7(attempt to re-open an already-closed object )

07-23 18:16:17.641: W/SQLiteConnectionPool(28390): A SQLiteConnection object for database ‘/storage/emulated/0/cnOA.db‘ was leaked!  
Please fix your application to end transactions in progress properly and to close the database when it is no longer needed.

 

这个错误出现的原因是因 为我在一个数据库查询方法中调用了另一个数据库查询方法,我的数据库查询方法都是在开始的时候获取SQLiteDatabase对象,在结束的时候关闭 SQLiteDabse对象,结果内部的数据库查询方法在结束的时候直接关闭了SQLiteDatabase对象,导致外面的数据库查询操作报错,在这里 大家不要以为多获取了几个SQLiteDatabase对象就可以了,每个线程只能使用一个SQLiteOpenHelper,也就使得每个线程使用一个 SQLiteDatabase对象(多线程操作数据库会报错);

        解决办法就是我不再关闭内部数据库查询方法的SQLiteDatbase对象或者将那个方法直接集成到外面的查询方法中,当然,要确保这个查询方法只会出 现其他数据库查询方法中,要是单独用这个方法,反而会因为SQLiteDatabase对象没有关闭而报错

文字来源:http://blog.csdn.net/zhufuing/article/details/14455823