请问一个 SQL 批量更新的问题

211 天前
 ysn2233

有需求要求减少与数据库的交互次数,希望能一次通信实现很多行数据一起更新(更新的列值都不一样)。 开始想的是用INSERT INTO mytable(a, b, c) VALUES (a1,b1,c1),(a2,b2,c2) ON DUPLICATE KEY UPDATE a=values(a), b=values(b),c=values(c)这种方式,但是又要求,b 的值要大于数据库原有的值才行, 就是类似于INSERT INTO mytable(a, b, c) VALUES (a1,b1,c1),(a2,b2,c2) ON DUPLICATE KEY UPDATE a=values(a), b=values(b),c==values(c) WHERE values(b) > b这种结果,但是 INSERT 的语法又不支持 WHERE 条件。

然后想的是多条 UPDATE 同时执行,分号隔开那种,但是这种情况好像如果要一次性发送的话没法用 PrepareStatement 预编译?好像也没法防注入,而且这种情景貌似和数据库通信都是走的文本协议非二进制协议?

剩下的网上看着好像就都是UPDATE mytable SET b = ( CASE WHEN a=a1 AND b1>b THEN b=b1 WHEN a=a2 AND b2>b THEN b=b2, c=c2), c = ( CASE WHEN a=a1 AND b1>b, c=c1, WHEN a=a2 AND b2>b THEN c=c2)或者是 INSERT INTO 配合 IF 函数,感觉都好繁琐 ,求指教最好的办法是什么

1124 次点击
所在节点    MySQL
2 条回复
youngPacce
211 天前
ysn2233
211 天前
@youngPacce 感谢大佬我研究一下

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

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

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

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

© 2021 V2EX