首页 > 数据库 >sql中exists 和 in的对比

sql中exists 和 in的对比

时间:2023-02-20 15:46:50浏览次数:32  
标签:exists cc T2 查询 sql where 对比 select

EXISTS语法解析

EXISTS 运算符用于判断查询子句是否有记录,如果有一条或多条记录存在返回 True,否则返回 False。

比如说下边的语法,子查询中的column_name可以和主查询中的列名字不一样,因为子查询只返回yes or no。

subquery 是一个受限的 SELECT 语句 (不允许有 COMPUTE 子句和 INTO 关键字)。

SELECT column_name(s)
FROM table_name
WHERE EXISTS
(SELECT column_name FROM table_name WHERE condition);

IN 语法解析

IN 操作符允许您在 WHERE 子句中规定多个值

SELECT column1, column2, ...
FROM table_name
WHERE column IN (value1, value2, ...);

IN比较好理解 就是判断主查询体中的字段的值是否在子查询结果集中存在

 

分析IN和EXISTS查询过程

从效率来看: 

1) select * from T1 where exists(select 1 from T2 where T1.a=T2.a) ;

    T1数据量小而T2数据量非常大时,T1<<T2 时,1) 的查询效率高。

2) select * from T1 where T1.a in (select T2.a from T2) ;

     T1数据量非常大而T2数据量小时,T1>>T2 时,2) 的查询效率高。
3) select * from T1 where T1.a in (select T2.a from T2) ;

     T1数据量非常大而T2数据量也非常大时,3) 的查询效率高。
4) select * from T1 where T1.a in(exists) (select T2.a from T2) ;

     T1数据量非常小而T2数据量也非常小时,4) 的查询效率都无所谓了差别不大。
 
简而言之,一般式:外表大,用IN;内表大,用EXISTS。

 执行方式: 

通过使用EXISTS,Oracle会首先检查主查询,然后运行子查询直到它找到第一个匹配项,这就节省了时间。Oracle在执行IN子查询时,首先执行子查询,并将获得的结果列表存放在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中以后再执行主查询。这也就是使用EXISTS比使用IN通常查询速度快的原因。

 in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。

  一直以来认为exists比in效率高的说法是不准确的。

  如果查询的两个表大小相当,那么用in和exists差别不大。
如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:
例如:表A(小表),表B(大表)
1:
select * from A where cc in (select cc from B) 效率低,用到了A表上cc列的索引;
select * from A where exists(select cc from B where cc=A.cc) 效率高,用到了B表上cc列的索引。   相反的
2:
select * from B where cc in (select cc from A) 效率高,用到了B表上cc列的索引;
select * from B where exists(select cc from A where cc=B.cc) 效率低,用到了A表上cc列的索引。   附录  

标签:exists,cc,T2,查询,sql,where,对比,select
From: https://www.cnblogs.com/dbahrz/p/17137658.html

相关文章

  • mysql正则替换 正宗!
    先看个官方例子mysql>SELECTREGEXP_REPLACE('abc','b','X');+-----------------------------------+|REGEXP_REPLACE('abc','b','X')|+------------------......
  • sqlserver本机数据库开放外部访问【copy收藏】
    一)首先是要检查SQLServer数据库服务器中是否允许远程链接。其具体操作为:(1)打开数据库,用本地帐户登录,右击第一个选项,选择属性:   (2)在打开的属性窗口,在其右边点击“连......
  • CentOS 7 安装PostgrelSQL-11
    sudoyuminstall-yhttps://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpmsudoyuminstall-ypostgresql11-ser......
  • MySQL的varchar定义长度到底是字节还是字符,varchar字符长度的计算
    1.在开始之前先简单介绍下字符和字节的区别:字符人们使用的记号,抽象意义上的一个符号。一个汉字和英文就是一个字符,如'1','中','a','$','¥',……字节计算机中存储......
  • 对比冒泡排序--PHP + python
    PHP写法:functionsortCustom($arr):array{for($i=0;$i<count($arr);$i++){for($j=0;$j<count($arr)-$i-1;$j++){if($arr[$......
  • MySQL中length()、char_length()的区别和用法
    方法概述:char_length(str)计算单位:字符不管汉字还是数字或者是字母都算是一个字符length(str)计算单位:字节utf8编码:一个汉字三个字节,一个数字或字母一个字节。gbk......
  • MySQL性能调优必知:Performance Schema引擎的配置与使用
    当你在MySQL高并发情况下的进行性能调优时,需要知道调整后的影响。例如查询是否变快了?锁是否会减慢运行速度?内存使用情况如何?磁盘IO等待时间变了吗?.PerformanceSchema就......
  • MySQL 创建数据库
    1.1进入MySQL命令:mysql-utest-p;1.2查看数据库命令:SHOWDATABASES;1.3新建数据库命令:CREATEDATABASEitem_name;1.4验证是否查看成功命令:SHOW......
  • linux利用source命令导入sql文件
    1.创建数据库2.设置编码3.进入sql文件目录,使用msyql的source命令如下:source文件路径mysql>useg6monitor;mysql>source/app/t_sta_high_emission_vehicle.sql; ......
  • PHP连接数据库、执行SELECT的SQL语句、在页面上输出
    PHP连接数据库打开N11点击连接——mysql输入PHP数据库信息测试连接成功后第点击确定双击就可以连接执行SELECT的SQL语句在页面上输出<html>  <head>......