WAL模式下的Java SQLite:数据库已锁定

时间:2016-05-01 17:58:33

标签: java sqlite locking wal

我在多线程应用程序中使用SQLite。为了确保这不会导致问题,我将SQLite数据库设置为WAL模式。所有线程共享一个在运行时从未关闭的连接。 但是,我在执行批处理时遇到此错误,我不知道为什么会发生这种情况。所有对数据库的写入都是使用singlethreadexecutor完成的,读取是在多个线程中完成的。

java.sql.SQLException: database is locked 
at org.sqlite.DB.throwex(DB.java:370) 
at org.sqlite.DB.executeBatch(DB.java:302) 
at org.sqlite.PrepStmt.executeBatch(PrepStmt.java:93) 

提前致谢

1 个答案:

答案 0 :(得分:1)

找到答案:由于旧池系统的遗留问题,我在服务器重新加载后没有正确关闭连接。