大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说in与exists和not in 与 not exists的区别「建议收藏」,希望您对编程的造诣更进一步.
1、in 与 exists:
外表大,用IN;内表大,用EXISTS;
原理:
用in:外表使用了索引,直接作hash连接;
用exists:内表使用了索引,外表作loop循环再进行匹配;
2、not in与not exists:
性能:not in不走索引,所以一般都用not exists;
区别:还有一点区别就是,not in字段为null的不进行筛选出来;而使用not exists即可;
这也就是说有时定义字段,用not null比较好了,这样也能避免not in查询出错。
exists : 强调的是是否返回结果集,不要求知道返回什么, 比如:
select name from student where sex = “m” and mark exists(select 1 from grade where …) ,只要
exists引导的子句有结果集返回,那么exists这个条件就算成立了,大家注意返回的字段始终为1,如果改成“select 2 from grade where …”,那么返回的字段就是2,这个数字没有意义。所以exists子句不在乎返回什么,而是在乎是不是有结果集返回。
而 exists 与 in 最大的区别在于 in引导的子句只能返回一个字段,比如:
select name from student where sex = “m” and mark in (select 1,2,3 from grade where …)
,in子句返回了三个字段,这是不正确的,exists子句是允许的,但in只允许有一个字段返回,在1,2,3中随便去了两个字段即可。
而not exists 和not in 分别是exists 和 in 的 对立面。
exists (sql 返回结果集为真)
not exists (sql 不返回结果集为真)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6782.html