我正在研究android sqLite数据库,我无法在DataBase中插入记录 在代码中,我在启动应用程序时只打开一次数据库,并在那里设置了我的Application类变量的引用,以便我可以从代码的任何部分访问数据库,这很好。
问题是:我可以访问数据库,但我无法启动事务。它不会给我任何例外,但sqLiteDatabaseWrite.isDbLockedByOtherThreads()
会返回TRUE
。此外,在logcat中有一条警告消息:
WARN / SQLiteDatabase(19006):数据库锁定无法使用 30秒锁的当前所有者是1.继续在线程中等待: 14
任何解决方案?。
答案 0 :(得分:7)
感谢和我在一起。其实我解决了我的问题。我使用sqLiteDatabase.beginTransaction()
启动了一个SQLite数据库操作,我忘了结束此事务。我通过结束交易解决了这个问题。为了结束交易,我使用了以下代码:
sqLiteDatabase.setTransactionSuccessful();
sqLiteDatabase.endTransaction();
感谢。