关于exists 的使用
admin
2023-05-22 16:02:40
0

1、exists 字面意思存在。 

  EXISTS里的子查询结果集非空,EXISTS()子句的值就是true。 
  EXISTS里的子查询结果集为空,EXISTS()子句的值就是false。 

  SELECT * FROM SCOTT.EMP WHERE EXISTS(SELECT SYSDATE FROM DUAL); 
  此句将查出scott.emp表所有内容. 

  SELECT * FROM SCOTT.EMP WHERE EXISTS(SELECT * FROM scott.salgrade where 1=2) ; 
  返回空结果集 


   参考一下论述: 
   带有EXISTS谓词的子查询不返回任何数据,只产生逻辑真值“true”或逻辑假值“false”。 
   使用存在量词EXISTS后,若内层查询结果非空,则外层的WHERE子句返回真值否则返回假值。 
   由EXISTS引出的子查询,其目标列表达式通常都用*,因为带EXISTS的子查询只返回真值或假值, 
   给出列名无实际意义。 



2、用exists的相关子查询 
     
      明白相关子查询: 
      子查询的查询条件依赖于外层父查询的某个属性值,称这类查询为相关子查询。 
      求解相关子查询不能像求解不相关子查询那样,一次将子查询求解出来,然后求解父查询。 
      内层查询由于与外层查询有关,因此必须反复求值。 
       
       弄清相关子查询处理过程: 
       从概念上讲,相关查询的一般处理过程是: 
       首先去外层查询中表的第1个元组,根据它与内层查询相关的属性值处理内层查询, 
       若WHERE子句返回值为真,则取此元组放入结果表;然后再取表的下一个元组; 
       重复这个过程直到外层表全部检查完为止。 




  SQL> select a.ENAME  from  scott.emp a 
            where exists(select * from  scott.dept b where b.deptno=a.deptno); 

  ENAME 
  ---------- 
  SMITH 
  ALLEN 
  WARD 
  JONES 
  MARTIN 
  BLAKE 
  CLARK 
  SCOTT 
  KING 
  TURNER 
  ADAMS 
  JAMES 
  FORD 
  MILLER 

  查询到14记录. 


  相当于下sql: 
  select a.ENAME  from  scott.emp a 
   where a.deptno in (select b.deptno  from  scott.dept b ); 


exists子查询实际是通过关联别的表安某种条件缩小主查询的范围。 



3、not exists    简单的理解就是 not exists= not in 
      实际not  exists  取得是不属于exists限制条件的主表的数据集  



SQL>  select a.ENAME  from  scott.emp a 
             where exists(select * from  scott.dept b where b.deptno=a.deptno and b.deptno=10); 

ENAME 
---------- 
CLARK 
KING 
MILLER 


     select a.ENAME  from  scott.emp a 
      where not exists(select * from  scott.dept b where b.deptno=a.deptno and b.deptno=10) 

  ENAME 
  ---------- 
  SMITH 
  ALLEN 
  WARD 
  JONES 
  MARTIN 
  BLAKE 
  SCOTT 
  TURNER 
  ADAMS 
  JAMES 
  FORD 

  查询到11记录. 





4 、exists和in 

      in子句通常用在不相关子查询中。通常先执行子查询,将子查询的结构用于父查询。 
      子查询的查询条件不依赖于父查询,这类子查询称为不相关子查询。 
      
      关键字: 在Oracle SQL中取数据时in 和 exists 的区别? 
  在Oracle SQL中取数据时有时要用到in 和 exists 那么他们有什么区别呢? 

  1 性能上的比较 
  比如Select * from T1 where x in ( select y from T2 ) 
  执行的过程相当于: 
  select * 
    from t1, ( select distinct y from t2 ) t2 
  where t1.x = t2.y; 

  相对的 

  select * from t1 where exists ( select null from t2 where y = x ) 
  执行的过程相当于: 
  for x in ( select * from t1 ) 
     loop 
        if ( exists ( select null from t2 where y = x.x ) ) 
        then 
    OUTPUT THE RECORD 
        end if 
  end loop 
  表 T1 不可避免的要被完全扫描一遍 

  分别适用在什么情况? 
  以子查询 ( select y from T2 )为考虑方向,如果子查询的结果集很大需要消耗很多时间, 
  但是T1比较小执行( select null from t2 where y = x.x )非常快,那么exists就比较适合用在这里。 
  相对应得子查询的结果集比较小的时候就应该使用in. 

   



5、问题: 我创建了一个表来存放客户信息,我知道可以用 insert 语句插入信息到表中, 
                   但是怎么样才能保证不会插入重复的记录呢? 

  答案: 可以通过使用 EXISTS 条件句防止插入重复记录。 


  示例一:插入多条记录 

  假设有一个主键为 client_id 的 clients 表,可以使用下面的语句: 




  INSERT INTO clients 
  (client_id, client_name, client_type) 
  SELECT supplier_id, supplier_name, 'advertising' 
  FROM suppliers 
  WHERE not exists (select * from clients 
  where clients.client_id = suppliers.supplier_id); 


               个人批注:not exists不存在,也就是说后面的括号中只要返回了数据那么这个条件就不存在了, 
        可以理解为括号前的notexists是一个左表达式 ,括号后的查询是一个右表达式, 
        只有当右表达式返回的也是not exists(即后面的查询出来的结果是非空的)时,等式才成立。 






  示例一:插入单条记录 

  Code: 


  INSERT INTO clients 
  (client_id, client_name, client_type) 
  SELECT 10345, 'IBM', 'advertising' 
  FROM dual 
  WHERE not exists (select * from clients 
  where clients.client_id = 10345); 


  使用 dual 做表名可以让你在 select 语句后面直接跟上要插入字段的值,即使这些值还不存在当前表中。 

相关内容

热门资讯

默克尔:特朗普政府已向欧盟“宣... 5月18日,德国前总理默克尔在西德广播公司(WDR)主办的论坛上表示,特朗普上台后,美欧关系已经出现...
马斯克输了,输得干净利落 马斯克输了,输得干净利落。他诉讼OpenAI和奥特曼背弃初心,当年他捐赠3800万美元,是为了支持一...
多个全球首创,8项成果在光博会... 5月18日,第二十一届“中国光谷”国际光电子博览会在中国光谷科技会展中心盛大开幕,盛会以“光联万物、...
惠康科技获得外观设计专利授权:... 证券之星消息,根据天眼查APP数据显示惠康科技(001237)新获得一项外观设计专利授权,专利名为“...
宠物叫声能实时翻译成“人话”,... 极目新闻记者 杜光然 近日,一款能把宠物叫声翻译成“人话”的宠语翻译器备受关注,该产品来自刚成立不久...
湖北宣恩县汛情已致3人遇难 5月17日至18日,恩施州宣恩县沙道沟镇白水河村上游普降大到暴雨,最大降雨量达292.6毫米,导致河...
普京访华团规模会比特朗普的大吗... 在美国总统特朗普结束访华后,俄罗斯总统普京也将于5月19日至20日访华。俄方否认二者之间存在联系,同...
直击柳州地震震中太阳村镇:搜救... 5月18日0时21分,广西柳州市柳南区发生5.2级地震,震源深度8千米。凌晨时分,骤然地动山摇,打破...
开放式耳机到底能进化到哪一步?... 我发现,现在很多人买耳机,理由越来越朴素了。 不是为了什么 HiFi 音质,也不是为了图个清静,纯粹...
格陵兰岛自治政府总理见美特使,... 新华社奥斯陆5月18日电(记者张玉亮)哥本哈根消息:丹麦海外领地格陵兰岛自治政府总理延斯-弗雷德里克...