网络编程
位置:首页>> 网络编程>> 数据库>> 数据库查询优化之子查询优化

数据库查询优化之子查询优化

作者:qq_43193797  发布时间:2024-01-27 18:25:25 

标签:mysql,数据库,子查询,优化

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代替。

总结

来源:https://blog.csdn.net/qq_43193797/article/details/85252408

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com