Android DataBase被其他线程锁定

时间:2011-11-20 09:04:53

标签: android sqlite

我正在研究android sqLite数据库,我无法在DataBase中插入记录 在代码中,我在启动应用程序时只打开一次数据库,并在那里设置了我的Application类变量的引用,以便我可以从代码的任何部分访问数据库,这很好。

问题是:我可以访问数据库,但我无法启动事务。它不会给我任何例外,但sqLiteDatabaseWrite.isDbLockedByOtherThreads()会返回TRUE。此外,在logcat中有一条警告消息:

  

WARN / SQLiteDatabase(19006):数据库锁定无法使用   30秒锁的当前所有者是1.继续在线程中等待:   14

任何解决方案?。

1 个答案:

答案 0 :(得分:7)

感谢和我在一起。其实我解决了我的问题。我使用sqLiteDatabase.beginTransaction()启动了一个SQLite数据库操作,我忘了结束此事务。我通过结束交易解决了这个问题。为了结束交易,我使用了以下代码:

sqLiteDatabase.setTransactionSuccessful();
sqLiteDatabase.endTransaction();

感谢。