首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于更新的SQL炼金术多线程选择不起作用

用于更新的SQL炼金术多线程选择不起作用
EN

Stack Overflow用户
提问于 2016-08-06 22:26:49
回答 2查看 594关注 0票数 0

我在MySQL数据库表中包含“任务”。每个任务都有标志(不管是否接受)。

现在,例如,3个线程做:

代码语言:javascript
复制
query_base = session.query(PredykcjaRow).filter(
    PredykcjaRow.predyktor == predictor,
    PredykcjaRow.czy_wziete == False
)
query_disprot = query_base.join(NieustrRow, NieustrRow.fastaId == PredykcjaRow.fastaId)

query_pdb = query_base.join(RawBialkoRow, RawBialkoRow.fasta_id == PredykcjaRow.fastaId)
response = query_pdb.union(query_disprot)
response = response.with_for_update()
response = response.first()
if response is None:
    return None
response.czy_wziete = True
try:
    session.commit()
    return response
except:
    return None

每个线程都有自己的会话(ScopedSession),但所有3个线程都有相同的对象。

在配置中

代码语言:javascript
复制
tx_isolation..... REPEATABLE-READ
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-08-20 23:41:16

问题是工会声明。MySQL不提供用于UPDATE的累积选择-它在没有警告的情况下执行,但是行没有被锁定。

我在官方文件中找到了这个信息,但现在我做不到。如果有人可以,请发表评论。

票数 0
EN

Stack Overflow用户

发布于 2016-08-06 23:10:35

假设创建了范围会话,如下所示:

代码语言:javascript
复制
Session = scoped_session(sessionmaker(bind=engine))

确保你没有这样做

代码语言:javascript
复制
session = Session()
give_to_thread1(session)
give_to_thread2(session)

对于限定作用域的会话,您可以直接使用它。

代码语言:javascript
复制
Session.query(...)

因此,您的线程应该这样做:

代码语言:javascript
复制
def runs_in_thread():
    Session.add(...)
    # or
    session = Session()
    session.add(...)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38809288

复制
相关文章

相似问题

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