sqlite3多线程操作问题

在项目中使用sqlite3,有时会报database is locked

两种方式

1、多线程读,多线程写,只使用共同一个数据库连接,即使用同一个SQLiteHelper连接,调用sqlite3_busy_timeout

2、多线程读,单线程写,每个线程使用各自独立的数据库连接,但是需要开启wal模式,以开启数据库连接池

开启wal通过如下语句

sql 复制代码
pragma synchronous=NORMAL;
pragma journal_mode=WAL;
pragma wal_autocheckpoint=5000;
相关推荐
AC赳赳老秦4 分钟前
基于DeepSeek与接口文档的智能测试数据生成实践
数据库·elasticsearch·信息可视化·流程图·数据库架构·powerbi·deepseek
萧曵 丶9 分钟前
Redis在实际业务中的常见与高级用法详解
数据库·redis·缓存
while(1){yan}23 分钟前
Mybatis动态SQL
数据库·spring boot·sql·spring·java-ee·mybatis
2501_944934731 小时前
大专学历物流专员提升路径:数据分析对物流成本控制的价值
数据库
熊文豪1 小时前
KingbaseES数据库存储与内存管理完全指南:从核心原理到性能优化
数据库·性能优化·kingbasees·金仓数据库·电科金仓
易营宝1 小时前
独立站适合 B2B 外贸吗?成本、交付周期与多语言营销系统选型建议
数据库
邵伯正在输入1 小时前
Mysql锁之插入意向锁
数据库·mysql
qq19257230271 小时前
商品库存管理系统(MYSQL)
数据库·mysql
什么都不会的Tristan2 小时前
Feed流(关注推送)
java·前端·数据库