exist的一些用法

 --近来干活时发现对同事写的用exists的sql看不很懂,在网上搜集了些资料学习学习。

--下面这些说法不见的都对,有不对的地方请高手指正。

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 语句后面直接跟上要插入字段的值,即使这些值还不存在当前表中。


在MATLAB中,exist函数用于确定某个值(对象)是否存在。它有两种形式,一个参数和两个参数的形式。在一个参数的形式中,exist函数返回一个值来指示给定的对象是否存在。如果对象存在,则返回1;否则返回0。在两个参数的形式中,exist函数返回一个值来指示给定的对象是否存在,并且限定结果的类型。具体来说,如果对象存在且是指定类型的,则返回一个非零值;否则返回0。\[2\] 举个例子,如果我们想判断当前目录下是否存在名为'plot'的内嵌函数,我们可以使用exist函数来实现。通过调用exist('plot'),如果存在,则返回值为5,表示存在一个内嵌函数。如果不存在,则返回值为0。\[2\] 另外,exist函数还可以用来判断结构体是否为空。例如,我们定义一个空的结构体s,通过调用exist('s'),返回值为1,表示结构体s存在。但是通过调用exist('s.field'),返回值为0,表示结构体s中的字段field不存在。\[2\] 总之,exist函数在MATLAB中用于判断对象是否存在,并且可以限定结果的类型。 #### 引用[.reference_title] - *1* *3* [matlab之exist函数](https://blog.csdn.net/qq_42599968/article/details/103521741)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [matlab中exist函数用法](https://blog.csdn.net/xuxinrk/article/details/83013400)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值