为了账号安全,请及时绑定邮箱和手机立即绑定

为什么sql not in的执行效率那么低?

为什么sql not in的执行效率那么低?

慕后森 2018-11-25 09:05:20
为什么sql not in的执行效率那么低
查看完整描述

1 回答

?
HUWWW

TA贡献1874条经验 获得超12个赞

首先说明,in的效率就不高,not的效率更底,所以二者结合就效率不高了。
至于为什么,从大了说,in和not都跟索引没有关系,而且就算相关字段有索引二者也都不会走,走的都是全表查询,那么这肯定不会快。
再说语句本身,not in 首先要判断是不是in,然后在判断not,这是两个过程,相当于一个补集,等于判断了两次,那么自然也就会慢一些。
其实凡是涉及到否判断的都有这样的问题。所以个人一般不建议使用否判断的条件,就算需要有,也需要尽量简化查询内容以后使用(举个简单的例子,原来你的not in需要在1千条数据中查找,现在在10条数据中查找,自然是后者快一些),这样才能让查询更加快捷。

查看完整回答
反对 回复 2018-12-06
  • 1 回答
  • 0 关注
  • 1044 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信