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
全部评论

相关推荐

10-25 00:32
香梨想要offer:感觉考研以后好好学 后面能乱杀,目前这简历有点难
点赞 评论 收藏
分享
死在JAVA的王小美:哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈,我也是,让我免了一轮,但是硬气拒绝了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务