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;
相关推荐
CrazyClaz2 分钟前
NewSQL数据库TiDB
数据库·tidb
lambo mercy27 分钟前
python入门
前端·数据库·python
IT技术分享社区1 小时前
从删库到恢复:MySQL Binlog实战手册
数据库·mysql·程序员
小李云雾1 小时前
Python 多任务编程入门:进程的创建、同步与进程池使用
开发语言·数据库·python·oracle
AI题库1 小时前
PostgreSQL 18 从新手到大师:实战指南 - 2.6 PostgreSQL管理工具
数据库·postgresql
flying robot1 小时前
MYSQL8.0.44的lLinux - Generic的安装
数据库
四谎真好看2 小时前
MySQL 学习笔记(运维篇2)
数据库·笔记·学习·mysql·学习笔记
l1t2 小时前
将利用30行X算法求解数独的python程序转成DuckDB自定义函数并比较性能
数据库·python·算法·duckdb
墨白曦煜3 小时前
硬核图解:MySQL 是如何利用 MVCC + 锁实现“可重复读”的?
数据库·mysql
DarkAthena3 小时前
【DuckDB】探索函数调用新范式:点操作符链式调用
数据库·sql·duckdb