sqlite事务 及 PRAGMA synchronous = OFF;

bash 复制代码
begin;
PRAGMA synchronous = OFF;

commit;

PRAGMA synchronous = OFF; 是一个用于 SQLite 数据库的命令,它设置了数据库的同步模式。SQLite 是一个流行的嵌入式数据库管理系统,它通过不同的 PRAGMA 命令提供了多种设置和优化选项。

在 SQLite 中,synchronous PRAGMA 用于控制数据库引擎在写操作期间如何使用磁盘 I/O。这个设置会影响数据的完整性和性能。有三个主要的 synchronous 模式:OFFNORMALFULL

  • OFF : 当设置为 OFF 时,SQLite 引擎不会等待数据实际写入磁盘;它只是将数据发送到操作系统,并立即继续执行。这种模式提供了最快的操作速度,因为减少了磁盘 I/O 操作。然而,这也意味着在系统崩溃或电源故障的情况下,最近的写操作可能会丢失,因为数据可能还没被实际写入磁盘。

  • NORMAL : 在 NORMAL 模式下,SQLite 会在关键时刻(如事务提交)等待数据写入磁盘,但不像 FULL 模式那样频繁。这提供了数据完整性和性能之间的平衡。

  • FULL : FULL 模式确保数据在继续之前写入磁盘,从而提供最高级别的数据完整性。在这种模式下,每次写操作都会同步到磁盘,但性能会因为增加的 I/O 操作而降低。

总的来说,PRAGMA synchronous = OFF; 是一个性能优化设置,它牺牲了一些数据完整性以换取更快的写操作速度。在不太关心数据丢失风险的场景中,比如临时数据库或缓存,这个设置可能是有益的。然而,在需要确保数据安全和完整性的应用中,使用 OFF 模式需要谨慎。

相关推荐
FL4m3Y4n6 分钟前
MySQL缓存策略
数据库·mysql·缓存
wsx_iot8 分钟前
TDengine学习
数据库·学习·tdengine
不吃香菜的小趴菜27 分钟前
mysql数据库打包与导入
数据库·mysql
野犬寒鸦30 分钟前
Redis复习记录day1
服务器·开发语言·数据库·redis·缓存
njidf31 分钟前
实战:用Python开发一个简单的区块链
jvm·数据库·python
Rick199337 分钟前
慢SQL优化
数据库·python·sql
IvorySQL39 分钟前
速抢!HOW 2026 早鸟票最后 1 天,解锁开源数据库盛会全亮点
数据库·postgresql·开源
IvorySQL1 小时前
PostgreSQL 技术日报 (3月30日)|内核补丁密集更新,REPACK 并发与索引预读取进展
数据库·postgresql·开源
NineData1 小时前
从业务库到实时分析库,NineData构建MySQL到SelectDB同步链路
数据库·mysql·程序员
IvorySQL1 小时前
PostgreSQL 技术日报 (3月29日)|内核工具增强 + 安全能力升级
数据库·postgresql·开源