SQlLite Wal 模式

发布时间 2023-08-08 18:22:10作者: EEEEEEEEEEEEEEEEEEE

QLite WAL(Write-Ahead Logging)模式主要有以下几个优点:

1. 提高写入性能WAL模式将数据先写入日志文件,然后再定期更新到实际数据文件中。这避免了每次写入都要同步更新数据文件,大大提升了写入速度。

2. 提高并发性能WAL模式采用乐观锁并发控制,允许在同一数据库的多个连接中同时写入,并发性能好于rollback journal模式。

3. 提高崩溃恢复能力WAL日志包含尚未提交到数据文件的数据变更记录,即使数据库异常关闭,也可以通过WAL恢复未提交事务。

4. 支持热备份可以直接复制WAL文件来创建一个数据库的热备份,避免停库影响业务。

5. 支持点恢复WAL包含历史所有变更记录,可以基于某一历史时间点还原数据库。

6. 减少磁盘碎片长时间运行后,磁盘碎片较小,不需要常规优化数据库文件。

7. 支持跨平台复制不同系统平台间可以通过WAL实现数据库复制,这是rollback journal模式所不支持的。

综上所述,WAL模式可以带来写入性能、并发性能、崩溃恢复能力等方面的提升,在大多数场景下都是比rollback journal模式更好的选择

二、开启WAL模式

 

1. 通过 SQLite 命令行工具打开数据库。
sqlite3 test.db
2. 在数据库打开后,执行 PRAGMA 命令开启 WAL 模式。
sql
PRAGMA journal_mode=WAL;
3. 这样就可以开启 WAL 模式了。
4. 也可以在打开数据库时直接指定 journal_mode 参数来开启 WAL 模式。
sqlite3 test.db -journal WAL
5. 在应用程序中,可以在打开数据库连接时执行以下PRAGMA语句开启WAL模式:
sql
PRAGMA journal_mode=WAL;
6. 注意WAL模式要求SQLite版本在3.7.0或更高。
7. 如果想恢复到默认的rollback journal模式可以用:
sql 
PRAGMA journal_mode=delete;