欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

sqlite遇到database is locked(SQLITE_BUSY)问题的解决

程序员文章站 2022-03-13 08:47:11
...

早上来公司,测试部的同事说测试多用户并发操作时遇到sqlite报database is locked的问题,现象是进行多用户并发查询不会出现,但只要涉及增删改操作时就会出现以上问题。
初步分析原因是多用户对sqlite数据库进行增删改操作时事务控制,当一个用户对数据库进行增删改操作时,事务未完成,此时另外一个用户对数据库进行增删改,由于之前的用户事务未完成,当并发用户数量更多时,更容易出现线程不安全问题,于是在对数据库进行增删改操作的方法上使用synchronized关键字(注:由于当时是javase项目中未使用数据库持久化框架)public synchronized int addSecurities(SecuritiesInfo si) {…..},增加线程锁后,测试时,开20个线程跑程序没出现database is locked问题。但是开50个线程跑程序时又出现了database is locked问题,当时猜测原因可能是使用纯jdbc原因,于是继续修改代码,把数据库的连接改用c3p0连接池,改用数据库连接池后将线程开50跑程序模拟测试未出现database is locked问题。但是线程数开到100时又出现了database is locked问题.
最终解决方法是修改sqlite数据库的模式: pragma journal_mode = WAL,sqlite默认的是delete模式.

 

相关标签: sqlite jdbc