您好,匿名用户

mysql如何优化这条更新语句?

0 投票
    UPDATE yw_tmp_usr a SET a.hth=(SELECT b.hth FROM yhdang b WHERE a.business_key=b.dh )
    WHERE EXISTS (SELECT b.hth FROM yhdang b WHERE a.business_key=b.dh );

上面这条语句在Oracle中执行效率比mysql中高得多,在mysql中却总是没反应,甚至报错:1205。我修改了linux上的my.cnf文件,让innodb_lock_wait_timeout = 1200,但仍无结果,请问各位大神,8.5万的数据,这样更新大概需要多长时间,如何优化呢??

用户头像 提问 2017年 5月4日 @ Lady 下士 (562 威望)
分享到:

1个回答

0 投票

UPDATE yw_tmp_usr SET hth = T.hth

FROM (

SELECT hth, dh FROM yhdang  

) T

WHERE yw_tmp_usr.business_key = T.dh

用户头像 回复 2017年 5月4日 @ Vayne 中士 (1,311 威望)
提一个问题:

相关问题

0 投票
1 回复 34 阅读
用户头像 提问 2019年 5月18日 @ Hades 下士 (642 威望)
0 投票
0 回复 22 阅读
0 投票
0 回复 16 阅读
0 投票
1 回复 17 阅读
用户头像 提问 2019年 5月6日 @ Usopp 中士 (1,194 威望)
0 投票
1 回复 251 阅读
用户头像 提问 2017年 6月5日 @ Kennen 上士 (1,557 威望)

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

IT技术交流群 - 随意问
欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...