首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >排级阻塞

排级阻塞
EN

Stack Overflow用户
提问于 2018-10-11 17:19:06
回答 1查看 1.5K关注 0票数 5

我目前正在我的项目中使用小淘气作为ORM。在我目前的情况下,我有一些进程,每个进程都有一个数据库连接。所有这些进程都需要同时访问特定的表。我正在寻找一些方法,使他们在不使用中央控制器的情况下协调。为此,当一个进程读取一行时,它必须被锁定,并且没有其他进程可以读取该行。阻塞的进程应与其他未阻塞的行一起继续。

我搜索了一下,发现MySql已经有了内部锁定机制,描述了这里,显然必须在索引的列上使用它才能按预期运行(从这里开始)。但我在皮尤文件里找不到任何相关的东西。有提供这些功能的扩展吗?还是应该编写包含FOR Update子句的原始SQL查询?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-11 21:15:51

Peewee支持使用FOR UPDATE子句,我认为这可能是您想要的。它不会阻止其他客户端读取,但只要持有锁的事务处于打开状态,就会阻止修改。

例如:

代码语言:javascript
复制
with db.atomic():
    # lock note.
    note = Note.select().where(Note.id == 123).for_update().get()
    # As long as lock is held no other client can modify note.
票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52765716

复制
相关文章

相似问题

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