糖尿病康复,内容丰富有趣,生活中的好帮手!
糖尿病康复 > mysql 大表 驱动_MySql 小表驱动大表

mysql 大表 驱动_MySql 小表驱动大表

时间:2021-04-29 10:12:51

相关推荐

mysql 大表 驱动_MySql 小表驱动大表

在了解之前要先了解对应语法 in 与 exist。

in后的括号的表达式结果要求之输出一列字段。与之前的搜索字段匹配,匹配到相同则返回对应行。

mysql的执行顺序是先执行子查询,然后执行主查询,用子查询的结果按条匹配主查询。

exist后的括号里则无输出要求,exist判断后面的结果集中有没有行,有行则返回外层查询对应的行。

ps所以exist还可以这样写: 用常量替换* ,反正是判断有没有行,不需要实际传回的数据。

select * from A where exist(select 1 from B where B.id= A.id)

mysql的执行顺序是先执行主查询,将主查询的数据放在子查询中做条件验证。

大体看来貌似exist的执行效率比in低,但其实exists子查询在底层做了优化,会忽略select清单,也并不会对每条数据进行对比。

比如这里有两张表

在查询中最好使用小表驱动大表,因为在外层表循环内层的时候,会锁定外层表,如果大表在外,会锁定5k次 。

如果要求查询所有id相同的Aname 有两种查询方式

1.由B表驱动A表 会先执行子查询 大表驱动小表

2.由A表驱动B表 会先执行主查询 小表驱动大表

如果需求变为 查询所有id相同的Bname

1.小表驱动大表

2.大表驱动小表

这表明查询效果一样,可以从sql语句逻辑层面进行适当修改,从而提高查询效率。

参考网址:

Mysql 多表关联链接顺序说明

mysql8.0是可以改变执行顺序的,然后是否可以提高查询效率,也不清楚,一般用的少,了解下就可以了。

如果觉得《mysql 大表 驱动_MySql 小表驱动大表》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。