数据库查询优化之子查询优化
更新时间:2019年01月10日 14:05:16 作者:qq_43193797
今天小编就为大家分享一篇关于数据库查询优化之子查询优化,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
1. 案例
取所有不为掌门人的员工,按年龄分组!
select age as '年龄', count(*) as '人数' from t_emp where id not in (select ceo from t_dept where ceo is not null) group by age;

如何优化?
①解决dept表的全表扫描,建立ceo字段的索引:

此时,再次查询:

②进一步优化,替换not in。
上述SQL可以替换为:
select age as '年龄',count(*) as '人数' from emp e left join dept d on e.id=d.ceo where d.id is null group by age;

结论: 在范围判断时,尽量不要使用not in和not exists,使用 left join on xxx is null代替。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
相关文章
mysql 5.7.17 zip安装配置教程 mysql启动失败的解决方法
这篇文章主要为大家详细介绍了mysql 5.7.17 zip安装配置教程,以及mysql启动失败的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2019-06-06
mysql tmp_table_size和max_heap_table_size大小配置
这篇文章主要介绍了mysql tmp_table_size和max_heap_table_size大小配置,需要的朋友可以参考下2016-05-05
Win10 MySQL如何解决secure_file_priv在my.ini无法设置问题
这篇文章主要介绍了Win10 MySQL如何解决secure_file_priv在my.ini无法设置问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-04-04


最新评论