广告
返回顶部
首页 > 资讯 > 数据库 >关于exists 的使用
  • 415
分享到

关于exists 的使用

2024-04-02 19:04:59 415人浏览 八月长安
摘要

1、exists 字面意思存在。   EXISTS里的子查询结果集非空,EXISTS()子句的值就是true。   EXISTS里的子查询结果集为空,EXISTS()

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

您可能感兴趣的文档:

--结束END--

本文标题: 关于exists 的使用

本文链接: https://www.lsjlt.com/news/37621.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 关于exists 的使用
    1、exists 字面意思存在。   EXISTS里的子查询结果集非空,EXISTS()子句的值就是true。   EXISTS里的子查询结果集为空,EXISTS()...
    99+
    2022-10-18
  • 关于if exists的用法及说明
    目录1 判断数据库是否存在2 判断表是否存在3 判断存储过程是否存在4 判断临时表是否存在5 判断视图是否存在6 判断函数是否存在7 获取用户创建的对象信息 8 判断列是否...
    99+
    2022-11-13
  • 关于if exists的用法及说明
    目录1 判断数据库是否存在2 判断表是否存在3 判断存储过程是否存在4 判断临时表是否存在5 判断视图是否存在6 判断函数是否存在7 获取用户创建的对象信息 8 判断列是否存在9 判断列是否自增列10 判断表中...
    99+
    2022-09-26
  • MySQL关于命令的问题、Exists关键字
    truncate 与 delete 的区别 truncate table :删除内容、不删除定义、释放空间。 delete table : 删除内容、不删除定义、不释放空间。 drop table :删除内容和定义,释放...
    99+
    2017-12-20
    MySQL关于命令的问题 Exists关键字
  • mysql中关键词exists怎么使用
    这篇文章主要讲解了“mysql中关键词exists怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql中关键词exists怎么使用”吧!语法解释语法SELECT colu...
    99+
    2023-07-02
  • Mysql子查询关键字的使用方式(exists)
    目录1. all1.1 格式1.2 特点 1.3 操作2. any(some)1.1 格式1.2 特点1.3 操作3. in1.1 格式1.2 特点1.3 操作4. exist1.1 格式1.2 特点1.3 操...
    99+
    2022-07-07
    Mysql 查询关键字 Mysql关键字 Mysql子查询关键字 Mysql 关键字exists
  • 如何进行SQL SERVER中关于exists 和 in的简单分析
    这篇文章给大家介绍如何进行SQL SERVER中关于exists 和 in的简单分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。In与Exists这两个函数是差不多的,但由于优化方案...
    99+
    2022-10-19
  • Oracle/PLSQL的EXISTS使用
    下面的testa表没有数据,dept表有数据。直接select,有数据就会有结果集。        plsql的exists用于判断子查询是否有结果集返回,“exists (子查询)”子查询只要结果集有数据,则exis...
    99+
    2018-02-04
    Oracle/PLSQL的EXISTS使用
  • 关于TransactionScope使用
    TransactionScope 是一个用于管理事务的类,它提供了对事务的创建、提交和回滚的支持。通过 TransactionSco...
    99+
    2023-09-23
    使用
  • sql中exists和not exists怎么使用
    在SQL中,EXISTS和NOT EXISTS是用来检查子查询是否返回结果的条件表达式。- EXISTS:如果子查询返回至少一行结果...
    99+
    2023-08-16
    sql
  • Spring Data JPA 关键字Exists的用法说明
    Spring Data JPA 关键字Exists 查询数据库中的此数据是否已存在: 例子: 查询sys_user表中的一个user是否存在,类SysUser对应的是数据库中的sys...
    99+
    2022-11-12
  • SQL中NOT EXISTS的使用
    NOT EXISTS是SQL中的一个条件运算符,用于检查子查询的结果集是否为空。它的语法如下:```SELECT colum...
    99+
    2023-09-22
    SQL
  • python中关于xmltodict的使用
    目录python中xmltodict使用xml转换成OrderedDictdict转换成xmlxmltodict模块处理xml数据基本用法1. parse2. unparse总结py...
    99+
    2023-03-14
    python xmltodict python xmltodict使用 python使用xmltodict
  • 关于Navicat15的激活使用
    注意 一定要按照步骤激活 第一步:打开注册机器,然后点击patch,找到安装Navicat15目录下面的exe文件 第二步:打开Navicat启动文件,然后点击注册按钮,然后点击注册机器的Generate按钮,把文本中的内容填写进去,然...
    99+
    2019-02-25
    关于Navicat15的激活使用
  • 关于MySQL的使用规范
    这篇文章主要介绍关于MySQL的使用规范,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!最近涉及数据库相关操作较多,公司现有规范也不是太全面,就根据网上各路大神的相关规范,整理了一些自...
    99+
    2022-10-18
  • 关于BeanUtils.copyProperties(source, target)的使用
    BeanUtils.copyProperties 首先,使用的是org.springframework.beans.BeanUtils; source 来源, target 目标 顾...
    99+
    2022-11-12
  • 关于pyqtSignal的基本使用
    目录pyqtSignal的基本使用关于pyqtSignal()作用pyqtSignal的基本使用 下面包含了对pyqtSignal的基础使用,包括多参数 因为较为简单,就当作参考书吧...
    99+
    2022-11-11
  • 关于@Bean的使用方式
    目录一个对象获取这个类的方法1、AnnotationConfigApplicationContext 类获取2、在spring自动创建的类中3、使用 @Autowired 注解获取变...
    99+
    2022-11-13
  • PyTorch中关于tensor.repeat()的使用
    目录关于tensor.repeat()的使用Tensor.repeat()的简单用法关于tensor.repeat()的使用 考虑到很多人在学习这个函数,我想在这里提 一个建议: 强...
    99+
    2022-11-13
    PyTorch tensor.repeat() tensor.repeat()的使用 PyTorch使用tensor.repeat()
  • 关于TransparentBlt的使用方法
    TransparentBlt是GDI函数之一,用于在Windows平台上绘制透明图像。它可以将源图像的一部分或全部绘制到目标设备上,...
    99+
    2023-08-08
    TransparentBlt
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作