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;
相关推荐
scan7241 小时前
龙虾读取session历史消息
java·前端·数据库
TDengine (老段)1 小时前
TDengine IDMP 可视化 —— 饼图
大数据·数据库·人工智能·物联网·时序数据库·tdengine·涛思数据
认真的薛薛1 小时前
GPU运维:vllm启动大模型参数解析
运维·数据库·vllm
刘~浪地球2 小时前
Redis 从入门到精通(九):事务详解
数据库·redis·缓存
熊文豪2 小时前
当系统在后台偷偷“记账“:KES 性能观测体系深度解析
linux·运维·服务器·数据库
jarvisuni2 小时前
GLM-5V-Turbo多模态测试,克隆Claude官网!
数据库
Full Stack Developme3 小时前
MySQL 触发器 存储过程 介绍
数据库·mysql
杨云龙UP3 小时前
MySQL慢查询日志暴涨导致磁盘告警:slow query log膨胀至397G的生产故障排查:清理、参数优化
linux·运维·服务器·数据库·mysql
Bat U3 小时前
MySQL数据库|视图+索引
数据库·mysql
SQVIoMPLe4 小时前
[拆解LangChain执行引擎]以Actor模型的视角来看Pregel
服务器·数据库·langchain