mysql 怎么 update 选择 select 的内容。

2016 年 6 月 27 日
 ebony0319
我刚开始会很简单,但是一查各种说法的都有。 update 怎么去更新表以 select 的内容呢?
3954 次点击
所在节点    MySQL
12 条回复
Hyponet
2016 年 6 月 27 日
in
hiboshi
2016 年 6 月 27 日
update xxx where id in ( select id from table where xxx=xx)
这样?
anexplore
2016 年 6 月 27 日
@hiboshi 效率如何
otakustay
2016 年 6 月 27 日
@anexplore mysql 的 in 很快,效率取决于后面那个 where 有没有跑索引
skydiver
2016 年 6 月 27 日
@otakustay mysql 的 in 效率很低,里面会循环的每条记录都运行一遍
otakustay
2016 年 6 月 27 日
@skydiver 你所谓的每条记录都运行一遍,是运行什么? in 的字段(这个 case 中是 id )有索引的时候根本不需要走全表
skydiver
2016 年 6 月 27 日
@otakustay 你可以 explain 一下看看。

mysql 会认为 in 语句里面是 dependent subquery ,然后就变成了扫外面的全表,然后再对每条记录进行里面的子查询。所以速度非常慢。

所以在 mysql 里要尽量用 join 而不要用 in 子查询。
otakustay
2016 年 6 月 27 日
@skydiver 做了一下实际尝试,结果如下:

https://gist.github.com/otakustay/c0278141a8f74e3d2a744df8d32c48d2

在索引得当的情况下,并未看到有 dependent subquery

mysql Ver 14.14 Distrib 5.7.13, for osx10.11 (x86_64) using EditLine wrapper
otakustay
2016 年 6 月 27 日
@skydiver 又试了一下,主句是 update 的时候确实是 dependent subquery ,我思考问题的时候把两者分离了,并未实际考虑到 update 和 select 的不同,我的错
justfindu
2016 年 6 月 27 日
@otakustay
@skydiver 你们两个讲的肯定不是同一个 mysql 版本~ in 效率在 5.7 很大提升...5.5 之前的貌似是挺慢= =
szopen
2016 年 6 月 27 日
ebony0319
2016 年 6 月 27 日
@szopen 搞懂了,必须用 INNER JOIN ,顺便补充一下,最好在之前设置: SET SQL_SAFE_UPDATES = 0;

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

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

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

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

© 2021 V2EX