SQLite中并发读写的策略

前端之家收集整理的这篇文章主要介绍了SQLite中并发读写的策略前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个sqlite数据库,我在进程A中保持打开和写入.我希望能够以只读方式从进程B使用它.

根据the document,

>如果数据库是UNLOCKED,数据库可能不会被读取(或写入) – 不合适
>如果数据库是SHARED,那么两个进程可以读取它,但是第一个不能写 – 不合适
>如果进程想要写入它需要一个EXCLUSIVE锁,这意味着没有其他进程可以写 – 不合适

过程A将会做很多小写,所以我不认为每次交易提交时都会生效.

我可以看到的唯一方法是让读者等到数据库进入UNLOCKED状态,在读取期间获得一个SHARED锁,然后释放它.同时进程A将要写入并且将被阻塞,直到锁可用 – 如果有的话(如果进程B崩溃了?).这意味着进程A和进程B将争用锁–B想要SHARED并且A需要EXCLUSIVE,这将减缓事情,甚至导致并发问题.

有没有办法实现我的同时写作和阅读的目的?

使用 WAL mode.它支持并发读者和一位作家.
原文链接:https://www.f2er.com/sqlite/197590.html

猜你在找的Sqlite相关文章