SQlite源码分析

性能问题

在一般情况下,WAL会提高SQLite的事务性能但是在某些极端况下,却会导致SQLite事务性能的下降。

    1.在事务执行时间较长或者要修改的数据量达到GB级的时候,WAL文件会被占用,它会暂时阻止checkpoint的执行(checkpoint会清空WAL文件),这将导致WAL文件变得很大,增加寻址时间,最终导致读写性能的下降。

     2.当checkpoint执行的时候,会降低当时的读写性能,因此,WAL可能会导致周期性的性能下降。