主页 > 知识库 > 数据库查询优化之子查询优化

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

热门标签:电话机器人市场趋势 电销机器人 行业 电销机器人各个细节介绍 温州瑞安400电话怎么申请 淄博400电话申请 俄国地图标注app 百度地图标注后不显示 昆明电信400电话办理 南昌高频外呼系统哪家公司做的好

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数据库查询优化 mysql效率
  • 海量数据库的查询优化及分页算法方案
  • 数据库查询优化(主从表的设计)
  • 优化MySQL数据库中的查询语句详解
  • 海量数据库的查询优化及分页算法方案集合1/2
  • 海量数据库的查询优化及分页算法方案集合2/2
  • 一次数据库查询超时优化问题的实战记录

标签:安徽 海口 葫芦岛 拉萨 洛阳 嘉峪关 甘南 吐鲁番

巨人网络通讯声明:本文标题《数据库查询优化之子查询优化》,本文关键词  数据库,查询,优化,之子,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《数据库查询优化之子查询优化》相关的同类信息!
  • 本页收集关于数据库查询优化之子查询优化的相关信息资讯供网民参考!
  • 推荐文章