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

早上来公司,测试部的同事说测试多用户并发操作时遇到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模式.

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值