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;
相关推荐
原来是猿5 分钟前
MySQL【用户管理】
数据库·mysql
2501_9454235415 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
2401_8463416517 分钟前
用Pandas处理时间序列数据(Time Series)
jvm·数据库·python
2401_8318249630 分钟前
编写一个Python脚本自动下载壁纸
jvm·数据库·python
2401_8579182940 分钟前
Python在2024年的主要趋势与发展方向
jvm·数据库·python
IvorySQL1 小时前
PostgreSQL 19 重磅新语法终于补齐这个缺口
数据库·postgresql·开源
IvorySQL1 小时前
PostgreSQL 技术日报 (3月23日)|使用 rdtsc 减少 EXPLAIN ANALYZE 的计时开销
数据库·postgresql·开源
yhole1 小时前
SQL中的REGEXP正则表达式使用指南
数据库·sql·正则表达式
IvorySQL1 小时前
PostgreSQL 技术日报 (3月21日)|这些机制,可能并非 “ 理所当然 ”
数据库·postgresql·开源
m0_518019482 小时前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python