当前位置: 首页 > 编程笔记 >

详解sql中exists和in的语法与区别

西门淮晨
2023-03-14
本文向大家介绍详解sql中exists和in的语法与区别,包括了详解sql中exists和in的语法与区别的使用技巧和注意事项,需要的朋友参考一下

exists和in的区别很小,几乎可以等价,但是sql优化中往往会注重效率问题,今天咱们就来说说exists和in的区别。
exists语法:
select … from table where exists (子查询)
将主查询的结果,放到子查询结果中进行校验,如子查询有数据,则校验成功,那么符合校验,保留数据。

create table teacher
(
tid int(3),
tname varchar(20),
tcid int(3)
);
insert into teacher values(1,'tz',1);
insert into teacher values(2,'tw',2);
insert into teacher values(3,'tl',3);

例如:

select tname from teacher exists(select * from teacher);

此sql语句等价于select tname from teacher
(主查询数据存在于子查询,则查询成功(校验成功))

sql返回为空,因为子查询并不存在这样的数据。
in语法:
select … from table where 字段 in (子查询)

select ..from table where tid in (1,3,5) ;
select * from A where id in (select id from B);

区别:
如果主查询的数据集大,则使用in;
如果子查询的数据集大,则使用exists;
例如:

select tname from teacher where exists (select * from teacher);

这里很明显,子查询查询所有,数据集大,使用exists,效率高。

select * from teacher where tname in (select tname from teacher where tid = 3);

这里很明显,主查询数据集大,使用in,效率高。

到此这篇关于sql中exists和in的语法与区别的文章就介绍到这了,更多相关sql中exists和in语法区别内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!

 类似资料:
  • 本文向大家介绍MySQL exists 和in 详解及区别,包括了MySQL exists 和in 详解及区别的使用技巧和注意事项,需要的朋友参考一下 MySQL exists 和in 详解及区别 有一个查询如下: 这里面的EXISTS是如何运作呢?子查询返回的是OrderId字段,可是外面的查询要找的是CustomerID和CompanyName字段,这两个字段肯定不在OrderID里面啊,这是

  • 本文向大家介绍MySQL中in与exists的使用及区别介绍,包括了MySQL中in与exists的使用及区别介绍的使用技巧和注意事项,需要的朋友参考一下 先放一段代码 分析以上代码可以看到两行代码除了循环的次序不一致意外,其他并无区别,在实际执行时两者所消耗的时间和空间应该也是一致的。但是这仅仅是在Java中,现在我们转化一下情景,最外层循环是数据库中的连接操作,内层循环为查找操作,那么现在两次

  • 本文向大家介绍mySQL中in查询与exists查询的区别小结,包括了mySQL中in查询与exists查询的区别小结的使用技巧和注意事项,需要的朋友参考一下 一、关于exists查询 以上是一个典型的exists查询的sql语句。 它的作用方式是这样的:每次从vendor表中查询出一条数据,然后将这条数据中的vendor_prov_code值传递到exists查询中进行执行,也就是进行子查询的执

  • 本文向大家介绍详解Mybatis中的 ${} 和 #{}区别与用法,包括了详解Mybatis中的 ${} 和 #{}区别与用法的使用技巧和注意事项,需要的朋友参考一下 Mybatis 的Mapper.xml语句中parameterType向SQL语句传参有两种方式:#{}和${} 我们经常使用的是#{},一般解说是因为这种方式可以防止SQL注入,简单的说#{}这种方式SQL语句是经过预编译的,它是

  • 本文向大家介绍对比分析MySQL语句中的IN 和Exists,包括了对比分析MySQL语句中的IN 和Exists的使用技巧和注意事项,需要的朋友参考一下 背景介绍 最近在写SQL语句时,对选择IN 还是Exists 犹豫不决,于是把两种方法的SQL都写出来对比一下执行效率,发现IN的查询效率比Exists高了很多,于是想当然的认为IN的效率比Exists好,但本着寻根究底的原则,我想知道这个结论

  • 本文向大家介绍SQL中where和having的区别详解,包括了SQL中where和having的区别详解的使用技巧和注意事项,需要的朋友参考一下 概念 where where是一个约束声明,在查询数据库的结果返回之前对数据库中的查询条件进行约束,再返回结果前起作用,并且where后不能使用“聚合函数”。 聚合函数 对一组值执行计算,并返回单个值,也被称为组函数,经常与 SELECT 语句的 GR