mysql数据库优化 (一) in与not in

场景

查询一张表的数据是否存在于另一张表中
第一写法就是用in或者not in
例如

select * from a where id in (select aid from b)

优缺点

  • 直观
  • 效率低下(in会扫描全表)
  • 不适合大数据量

解决办法

  1. 使用EXISTS代替IN
select * from a where exists (select aid from b where a.id=b.aid)
  1. 使用左连接代替NOT IN,也可以用NOT EXISTS代替
select * from a 
left join b on a.id=b.aid
where b.aid is null
全部评论

相关推荐

07-11 15:12
门头沟学院 Java
别人在上班,我就在工位上看看视频啥的,这正常吗?
程序员小白条:实习就是摸鱼,只是公司指标,把你进来了,可能那时候客户很多,但等你进来的时候,已经是淡季了,根本没多少需求,或者说根本不适合实习生去完成,因此你就每天干坐着就行,可能1,2个月都没需求
实习生的蛐蛐区
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务