sqlite研究(1)

sqlite研究(1),第1张

概述7.2 独享访问模式   SQLite从3.3.14版本之后增加一个“独享访问模式”概念。当处于独享访问模式时,SQLite会在一个事务完成之后仍然保留独享锁。这将阻止其他进程访问这个数据库;由于大部分的开发都只有一个进程访问数据库,所以大部分情况下这不是一个严重的问题。独享访问模式的好处可以在三个方面减少磁盘IO数量:   1)        不再需要为每个事务完成之后修改文件头部的变更计数器。 @H_502_0@

@[email protected] 独享访问模式

@H_502_0@sqlite从3.3.14版本之后增加一个“独享访问模式”概念。当处于独享访问模式时,sqlite会在一个事务完成之后仍然保留独享锁。这将阻止其他进程访问这个数据库;由于大部分的开发都只有一个进程访问数据库,所以大部分情况下这不是一个严重的问题。独享访问模式的好处可以在三个方面减少磁盘IO数量:

@H_502_0@1) 不再需要为每个事务完成之后修改文件头部的变更计数器。这可以为回滚日志及数据库文件减少一次页写入。

@H_502_0@2) 没有其他进程会修改数据库,所以不必在一个事务开始的时候去检查变更计数器或者清除掉用户空间的缓存。

@H_502_0@3) 当一个事务完成之后,可以采用清空日志文件的方式,而不必去删除这个文件。在大多数的 *** 作系统中,清空文件要远快于删除一个文件。

@H_502_0@上述的第三点优化,清空而不是删除回滚日志文件,不再要求一直取得一个独享锁。在理论上,我们可以在任何时刻做这项优化,并不是只有在独享访问模式时。在将来的sqlite版本中我们或许可能这么做。但当前的版本(3.5.0)回滚日志文件清空优化只发生在独享访问模式。

总结

以上是内存溢出为你收集整理的sqlite研究(1)全部内容,希望文章能够帮你解决sqlite研究(1)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1177421.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存