请问一下 sqlalchemy 在乐观锁的时候,怎么知道自己更新了几行或者是否更新成功?

2018-12-26 20:50:36 +08:00
 whx20202

我理解 sqlalchemy 在事务中,update 不会立刻生效,甚至不会立刻发到服务器上,而是等到 commit 才生效。

举个例子:

with Seesion as session:
    object = session.query(Table).where(key=param).limit(1)

    content = "这里是业务逻辑计算的值"

    # 用取到的对象的 ID 进行更新,只有一个线程能更新成功,我理解
    Table.update(Table).set(Table.content = content).where(id = object.id)
    sessoin.commit()

那么问题来了,如果我想知道我 update 操作(或者说是 commit 操作)是否成功(影响了一行)该怎么办呢? 因为可能还有一些后续操作,需要确认更新成功,拿到锁才能继续

2914 次点击
所在节点    Python
6 条回复
gamexg
2018-12-26 20:57:02 +08:00
很长时间没用 python 了,
update 返回值应该是实际更新的函数。
SleipniR
2018-12-27 09:42:41 +08:00
如果 update 或 commit 不成功,会直接抛出异常吧。
拿到锁才能继续是什么意思?
keakon
2018-12-27 09:53:44 +08:00
1. 你这没有乐观锁
2. update 没在事务中
3. ResultProxy.rowcount 是更新的行数
lolizeppelin
2018-12-27 10:36:14 +08:00
query= session.query(Table).where(key=param).limit(1)
with session.begin():
____query.update({key: value})
____session.commt()

这样写才是事务
15399905591
2018-12-27 10:48:00 +08:00
你的问题没描述清楚,你是需要加锁操作,每次只能有一个对象能够更新 Table ?
whx20202
2019-01-03 17:19:14 +08:00
@keakon #3 感谢。
第二点确实是我写范例代码时候疏忽了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/521305

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX