GRDB使用SQLite的WAL模式

Posted 大学霸

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了GRDB使用SQLite的WAL模式相关的知识,希望对你有一定的参考价值。

GRDB使用SQLite的WAL模式
 
WAL全称是Write Ahead Logging,它是SQLite中实现原子事务的一种机制。该模式是从SQLite 3.7.0版本引入的。再此之前,SQLite使用Rollback Journal机制实现原子事务。在Rollback Journal机制中,当需要修改数据时,先把被修改的数据备份出来,然后把数据库的数据修改。如果事务成功,就把备份数据删掉;如果事务失败,则恢复备份数据。这个机制的缺点是读写频繁,并且写的时候,不能读取。
 
而WAL模式的工作机制如同其名称一样,在写入数据库之前,先写入一个日志文件。这个日志文件名为wal的文件。当事务成功,修改的内容会保留在这个文件中。当事务失败,则从这个文件中删除。当wal文件的记录积累到一定数量,则一次性写入数据库中。如果读取数据库,则先从wal中读取,然后再读取数据库文件。这样,写操作不会影响读操作,从而提高效率。
 
GRDB直接支持WAL模式。当开发者使用DatabasePool建立数据库连接,则默认使用WAL模式;如果使用DatabaseQueue建立连接,则不使用该模式。如果WAL中的积累数据太多时候,写入数据库会造成数据库性能下降,所以避免WAL积累数据太多。

以上是关于GRDB使用SQLite的WAL模式的主要内容,如果未能解决你的问题,请参考以下文章

sqlite之WAL模式

当连接未正确关闭时,为啥使用 WAL 模式的 SQLite 数据库中的数据会丢失?

Sqlite的事务,锁和WAL模式

Android 9.0 SQLiteCantOpenDatabaseException SQLITE_CANTOPEN(不支持WAL模式)源码分析定位

Android 9.0 SQLiteCantOpenDatabaseException SQLITE_CANTOPEN(不支持WAL模式)源码分析定位

Android 9.0 SQLiteCantOpenDatabaseException SQLITE_CANTOPEN(不支持WAL模式)源码分析定位