首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLite3与锁的释放

SQLite3与锁的释放
EN

Stack Overflow用户
提问于 2016-04-02 09:44:39
回答 1查看 1.1K关注 0票数 2

SQLite有不同级别的锁:UNLOCKEDSHAREDRESERVEDPENDINGEXCLUSIVE

我找不到调用SQLite API获取和释放锁的信息。

正如我所理解的,在sqlite3_step调用时获得了锁。锁的类型取决于准备语句的表达式。此外,此命令还可以升级自定义事务中写入操作的锁定。

据我所知,sqlite3_step也释放了写锁-这个函数返回SQLITE_DONE或错误代码。我没有找到任何文档,但是这个函数应该在执行结束时释放RESERVED/PENDING/EXCLUSIVE似乎是合理的。

但我不明白读操作会发生什么。要获得所有被查询的行,我们需要多次调用sqlite3_step --每个调用都会给出一行。

我从解锁通知API:it is not possible for one call to sqlite3_step() to return SQLITE_ROW and then the next SQLITE_LOCKED中找到了关于OS缓存和引用的it is not possible for one call to sqlite3_step() to return SQLITE_ROW and then the next SQLITE_LOCKED文档。

我假设在读取操作中,首先调用sqlite3_step获取SHARED锁并将数据从文件加载到OS缓存。如果sqlite3_step返回除SQLITE_ROW以外的任何内容(即SQLITE_DONE或错误代码),则释放锁。

是对的吗?

我们如何手动释放获取的锁进行读取操作?sqlite3_reset

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-04-03 09:00:33

SQLite在sqlite3_prepare中获取数据库/表的锁,并在sqlite3_finalize中释放它。锁的类型取决于SQL表达式。

因此,如果您创建了一个STMT -您需要执行它并尽快完成。否则你会阻塞不同的连接。

示例:如果您为SELECT表达式创建STMT -您获得了SHARED锁。因此,来自不同连接的所有写操作都会被阻塞,直到STMT完成为止。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36371659

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档