有需求要求减少与数据库的交互次数,希望能一次通信实现很多行数据一起更新(更新的列值都不一样)。
开始想的是用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 函数,感觉都好繁琐 ,求指教最好的办法是什么
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.