SQLLIte [SQLITE_BUSY] The database file is locked (database is locked) 问题

SqlLite是一个嵌入式轻量级文件数据库

  1. 侵入式 。 方便,不需要安装数据库,仅需要一个目录
  2. 轻量级。支持的数据量不大。
  3. 单文件。有文件锁。标题出现的问题就是触发了锁。

所以,sqlLite的锁是库锁,因为sqlLite的数据库就是一个后缀为 .db的文件,文件是有写锁的

因此给sqlLite分配太多链接没有意义。

这个问题就是因为并发触发了sqlLite的锁机制,解决方案就是变成顺序读和写,维护一个链接就可以了.

Hikari 配置示例如下 :

java 复制代码
        HikariDataSource hikariDataSource = new HikariDataSource();
        hikariDataSource.setAutoCommit(true);
        hikariDataSource.setJdbcUrl("jdbc:sqlite:D:/home/sqllite/database-visual/database.db");
        // 等待连接池分配连接的最大时长(毫秒),超过这个时长还没可用的连接则发生SQLException, 缺省:30秒
        hikariDataSource.setConnectionTimeout(10 * 60 * 1000);
        // 一个连接空闲状态的最大时长(毫秒),超时则被释放(retired),缺省:10分钟
        hikariDataSource.setIdleTimeout(10 * 60 * 1000);
        // 这里是SQLLite数据库,维护一条链接即刻,并非时排队
        hikariDataSource.setMinimumIdle(1);
        hikariDataSource.setMaximumPoolSize(1);

SqlLite很难应对高并发场景,sqllite是轻量数据库,适用于各种设备的客户端数据库,客户端直接面向用户,而用户的操作基本上都是顺序的,并且数据量不是很高。
本人在服务器中使用sqllite 使用来记录服务信息和一些不重要,数据量不是很大的订阅任务的,并且订阅信息会自动备份清理,也基本不会产生并并发查询。 大家使用sqllite还需要注意它的特征

相关推荐
難釋懷10 小时前
OpenResty实现Redis查询
数据库·redis·openresty
别抢我的锅包肉11 小时前
【MySQL】第四节 - 多表查询、多表关系全解析
数据库·mysql·datagrip
Database_Cool_11 小时前
OpenClaw-Observability:基于 DuckDB 构建 OpenClaw 的全链路可观测体系
数据库·阿里云·ai
刘~浪地球11 小时前
Redis 从入门到精通(五):哈希操作详解
数据库·redis·哈希算法
zzh08112 小时前
MySQL高可用集群笔记
数据库·笔记·mysql
Shely201712 小时前
MySQL数据表管理
数据库·mysql
爬山算法12 小时前
MongoDB(80)如何在MongoDB中使用多文档事务?
数据库·python·mongodb
APguantou13 小时前
NCRE-三级数据库技术-第2章-需求分析
数据库·需求分析
寂夜了无痕13 小时前
MySQL 主从延迟全链路根因诊断与破局法则
数据库·mysql·mysql主从延迟
爱丽_13 小时前
分页为什么越翻越慢:offset 陷阱、seek 分页与索引排序优化
数据库·mysql