SQLite3 如果突发断电、关机,数据到底会不会丢?
创始人
2025-12-15 11:02:00
0

SQLite是一个小型的数据库产品,但是其中的运维命令并不像想象的简单,这里核心的运维命令是PRAGMA,PRAGMA 语句是特定于 SQLite 的 SQL 扩展,用于修改 SQLite 库的操作或查询 SQLite 库的内部(非表)数据。PRAGMA 语句使用与其他 SQLite 命令。

这里有一个注意的地方,也就是PRAGMA命令本身,会进行更迭,同时在系统中使用错误的PRAGMA命令不会报错,这点是需要注意的。

PRAGMA 命令执行计划图

下面以数据库运维中的重要性和系统性能的重要性来进行关键命令的描述。

synchronous 这里有一个表,关于sqlite3的性能和数据安全性之间的比率:

这里在进入SQLite的时候需要考虑你的SQLite适用于哪种模型:

[root@localhost data]# sqlite3 test.db

SQLite version 3.47.1 2024-11-25 12:07:48

Enter ".help" for usage hints.

sqlite>

sqlite>

sqlite> PRAGMA synchronous = FULL;

sqlite>

sqlite> PRAGMA synchronous;

2

sqlite>

关键业务我们推荐FULL模式。

WAL日志刷新是SQLite一个关键的数据库运维项目,这里我们可以管控的是在断电后,到底需要多长时间数据库可以恢复工作的问题,这里就牵扯我们之前学习到了SQLite的工作模式,必须是wal然后我们的数据刷新上面提到的同步模式要是full 那么现在我们要决定的是数据页面的刷新率,也就是我们产生多少数据页面后,进行数据页面刷新的问题。

[root@localhost data]# sqlite3 test.db

SQLite version 3.47.1 2024-11-25 12:07:48

Enter ".help"for usage hints.

sqlite>

sqlite>

sqlite> PRAGMA synchronous = FULL;

sqlite>

sqlite> PRAGMA synchronous;

2

sqlite>

sqlite>

sqlite> PRAGMA wal_autocheckpoint;

1000

sqlite> PRAGMA wal_autocheckpoint = 200;

200

sqlite> PRAGMA wal_autocheckpoint;

200

sqlite> PRAGMA wal_checkpoint;

0|10179839|10179839

sqlite> PRAGMA wal_checkpoint(TRUNCATE);

0|0|0

sqlite> PRAGMA wal_autocheckpoint;

1000

sqlite> PRAGMA wal_checkpoint;

0|0|0

这里我们注意几个命令:

PRAGMA autocheckpoint;这个命令查看当前数据页面多少,才产生一次checkpoint 的工作。键入命令后会显示当前的配置是多少。

如果对数据页面触发值想进行改动,可以使用 PRAGMA wal_autocheckpint = 200; 这个意思是产生了200个页面就进行数据的刷新到磁盘的工作。

同时需要注意每次启动数据库都需要带有一个配置的文件的脚本,来加载配置否则SQLite是不会加载正确的预设配置给你。

所以你的JAVA程序在启动SQLite的时候,应该将这些写入,或者写一个脚本如下:

PRAGMA journal_mode = WAL;

PRAGMA synchronous = FULL;

PRAGMA wal_autocheckpoint = 200;

把这些存储在一个.sql文件中,然后启动的时候,但是在操作中我发现了一个新的问题,关于一些配置可以固化,一些不可以,这里我们总结了一个表。

一、SQLite PRAGMA 持久化 vs 非持久化

1、持久化 PRAGMA(Persistent)

这些 PRAGMA 会写入数据库文件,对所有连接永久生效。

2、会话级 PRAGMA(Non-persistent)

这些只影响当前连接或事务,不会写入数据库文件。

学到这里,那就出现一个问题,一个库或者一个SQLite的数据库要进行哪些初始化设置。

对新库的初始化包含了如下的设置:

1)数据库存储文本的编码

2)数据库页面的大小

3) 设置文件身份标识

4)设置数据文件的版本

5)控制SQLite是否进行磁盘空间的回收

6)设置数据库运行的模式

下面是这六项,在LINUX 和WINDOWS 中的比对异同点。

二、SQLite 在 Linux 与 Windows 下的关键 PRAGMA 差异说明

1、数据库存储文本的编码(PRAGMA encoding)

结论: SQLite 行为完全一致,主要差异来自 Windows 终端默认不是 UTF-8。

2、数据库页面大小(PRAGMA page_size)

结论: 两平台行为一致,4K 页通常最佳。

3、 文件身份标识(PRAGMA application_id)

示例:sql PRAGMA application_id = 0x1234ABCD;

下面是这些命令的几种集合,可以将这些进行一个标准化的设置:

1)设置数据库编码(仅空库且未建表时有效)

PRAGMA encoding = 'UTF-8';

2)设置数据库页面大小(仅空库有效)

PRAGMA page_size = 4096;

3)设置 database file 的 application id(应用识别)

PRAGMA application_id = 0x1234ABCD;

4)设置数据库 schema 版本(供程序使用)

PRAGMA user_version = 20240101;

5)设置自动回收空间模式(写入数据库文件结构)

NONE / FULL / INCREMENTAL PRAGMA auto_vacuum = FULL;

6)设置日志模式(journal_mode)

DELETE / TRUNCATE / PERSIST / MEMORY / WAL PRAGMA journal_mode = WAL;

7)设置同步级别(磁盘安全等级)

OFF / NORMAL / FULL / EXTRA PRAGMA synchronous = NORMAL;

8)WAL 模式下自动 checkpoint 间隔(不持久化,每次连接需设置)

PRAGMA wal_autocheckpoint = 200;

9) 可选:严格表(类似强类型)

CREATE TABLE t(a INTEGER, b TEXT) STRICT;

10)可选:快速收缩空间

PRAGMA incremental_vacuum;

作者介绍

刘华阳,20年经历风霜雨打的 DBA,5年的 DBA 架构和团队管理经验,只要是数据库都喜欢学习。PostgreSQL ACE,MongoDB 狂热者,10年的 MYSQL 工作经验,现在在玩 POLARDB 与时俱进。

来源丨公众号:AustinDatabases(ID:AustinDatabases)

dbaplus社群欢迎广大技术人员投稿,投稿邮箱:editor@dbaplus.cn

相关内容

广东江门成立联合执法工作组...
针对媒体曝光的陈皮年份虚标等问题,广东省江门市新会区市场监督管理局...
2025-12-15 16:42:09
如何落实中央经济工作会议精...
中央经济工作会议12月10日至11日在北京举行,总书记出席会议并发...
2025-12-15 16:41:48
“太宗之后无祖”为何多次被...
古代帝王庙号中,最尊贵的是“太祖”,其次是“太宗”。所谓“太”即第...
2025-12-15 16:02:41
如何带娃上班两不误?一图读...
如何破解宝爸宝妈育儿与上班两难问题?本市人社部门为此推出了“生育友...
2025-12-15 16:02:37
国际人士瞩目中央经济工作会...
岁暮天寒,暖意东来。中央经济工作会议日前在北京闭幕,世界再次聚焦中...
2025-12-15 11:31:53
SQLite3 如果突发断...
SQLite是一个小型的数据库产品,但是其中的运维命令并不像想象的...
2025-12-15 11:02:00

热门资讯

孕妈检测出胎儿没有“胎心”究竟... 原标题:孕妈检测出胎儿没有“胎心”究竟为何?多半是这4种原因,预防下 昨天小樱...
耳聋耳背知识分享-----耳朵... 耳朵听力下降恢复方法首先要找出听力下降的病因,其次针对病因进行对症治疗。 耳朵听力下降,如何恢复听...
原创 如... 肺是人体非常重要的器官,空气中的很多灰尘和垃圾都会随空气进入肺部,所以肺部的清洁是非常重要的。我们可...
激光术后护理指南:如何科学恢复... 二氧化碳激光是一种常用于去除瘢痕、色素沉着、皱纹和其他皮肤问题的治疗方法。它通过发射高能量的二氧化碳...
如何有效应对低血压问题,提升生... 血压低,这个问题在生活中并不罕见。很多人可能会觉得,血压低就像是个小毛病,不用太在意。但实际上,低血...
孩子自控力差?家长如何引导培养 孩子自控力差?家长如何引导培养 在孩子的成长过程中,自控力是一项至关重要的能力。它关乎孩子的学业表现...
原创 婴... 在宝宝的成长过程中,奶粉作为重要的营养来源,其选择至关重要。那么,什么样的婴儿奶粉比较好呢?奶粉的营...
存款利息怎么算?湖南农商行存款... 导读湖南农商行存款利息怎么算?湖南农商行作为湖南最大的股份制银行,它是一家地方性、集约化、国际化、股...
宝宝不吸奶瓶的问题如何解决 原标题:宝宝不吸奶瓶的问题如何解决 宝宝出生后不久,有些妈妈因为要上班而不得不...
科普|秋季“花粉过敏”症状有哪... 不少人在秋冬来临之际,会出现反复打喷嚏、流鼻涕、鼻塞、眼睛发痒、呼吸不畅等症状,这有可能是遭遇了“花...