用 SQLAlchemy 的 session 怎么执行 update 语句

2016-10-11 15:25:41 +08:00
 crytis

sql 是这样的 UPDATE table_RP set send_times=send_times+1 WHERE id in (0,1,2,3),我的参数是后面 in 里面的,一个 list ,如何用 session 执行呢。我用了 session.execute(),试了好多次都不行

3641 次点击
所在节点    Python
3 条回复
crytis
2016-10-11 15:48:42 +08:00
目前先手动拼的 SQL😂
lrh3321
2016-10-11 15:58:00 +08:00
session.query(table_RP).filter(table_RP.id.in_((0,1,2,3))).update({table_RP.send_times: table_RP.send_times+1})

类似这样的写法
crytis
2016-10-11 17:35:26 +08:00
@lrh3321 可以的 不过会报错 。在 update 里加上 synchronize_session='fetch' 这个就好了

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

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

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

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

© 2021 V2EX