数据库 
首页 > 数据库 > 浏览文章

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

(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )

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 8.0.13设置日期为0000-00-00 00:00:00时出现的问题解决
下一篇:详解Mysql数据库date, datetime类型设置0000-00-00默认值(default)报错问题
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。