有需求要求减少与数据库的交互次数,希望能一次通信实现很多行数据一起更新(更新的列值都不一样)。
开始想的是用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 函数,感觉都好繁琐 ,求指教最好的办法是什么
1
youngPacce 256 天前
https://zzy1blog.cn/2023/12/16/mysql%e6%89%b9%e9%87%8f%e6%9b%b4%e6%96%b0%e7%9a%84%e4%b8%80%e7%a7%8d%e6%96%b9%e5%bc%8f/
可以参考一下,使用 union all + inner join 关联实现的 |
2
ysn2233 OP @youngPacce 感谢大佬我研究一下
|