永胜彩票

当前位置:源码库-建站教程-数据库教程-MYSQL教程-数据库查询优化之子查询优化-MYSQL教程-源码库|专注为中国站长提供免费商业网站源码下载!

数据库查询优化之子查询优化-MYSQL教程-源码库|专注为中国站长提供免费商业网站源码下载!

时间:2019-03-27来源/作者: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代替。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对ASPKU源码库的支持。


注:相关教程知识阅读请移步到MYSQL教程频道。
相关MYSQL教程
热门标签