当前位置: 首页 > news >正文

not in not exists

select id1 from test1 where id1 not  in (select id2 from test2)

第一步: 执行 子查询 select id2 from test2, 子查询 返回一个 结果 集

第二部: 根据 主查询的 条件, 将 主表中的 每一行 都和 结果集进行比较

第三步: 如果 比较的结果是 TRUE,则表示不存在结果集中,FALSE 表示 存在结果集中

如果 结果集中 存在 NULL 值,则 整个查询 不返回任何结果。因为任何值与 NULL 比较 结果为 UNKNOWN,所以 不会返回。

select * FROM test1 where NOT EXISTS (select * from test2 where id2 = id1 )

1. 相关子查询:NOT EXISTS 子查询通常是一个相关子查询,这意味着它会引用外部查询中的字段。次外部查询处理一时子查询都会重新执行一次。  
2. 检查存在性:NOT EXISTS 子查询的目的是检查子查询是否返回任何行。如果子查询返回至少一行,则 NOT EXISTS 返回 FALSE;如果子查询不返回任何行,则 NOT EXISTS 返回 TRUE。  
3。 短路评估:一旦子查询找到匹配的行,NOT EXISTS 就会立即返回 FALSE,而不会继续扫描剩余的行。这种短路评估提高了查询效率。  
4. 处理 NULL 值:与 NOT IN 不同,NOT EXISTS 不会受到 NULL 值的影响。即使子查询结果中包含 NULL 值,NOT EXISTS 仍然可以正常工作,因为它只检查是否存在行,而不关心具体的值

相关文章:

  • 设计模式-策略模式、命令模式
  • 使用vite脚手架搭建react项目
  • 内网穿透的应用-全流程解析如何通过VNC实现Windows与MacOS远程桌面的无缝连接
  • vue2升级Vue3--native、对inheritAttrs作用做以解释、声明的prop属性和未声明prop的属性
  • c语言题目 拷贝函数参数
  • c# 利用mv-cs200-10gc工业相机,识别液注的高度
  • 3DS模拟器使用(pc+安卓)+金手指+存档互传
  • Java蓝桥杯
  • 万邦大数据
  • 词向量:优维大模型语义理解的深度引擎
  • 【华为OD机考真题】- 用户调度问题(Java)
  • C++相关基础概念之入门讲解(上)
  • 全面!陕西省10市企业技术中心申报条件奖补和认定补助材料、时间汇集
  • linux ptrace 图文详解(二) PTRACE_TRACEME 跟踪程序
  • # 使用OpenAI Agents实现智能代理的生命周期管理
  • 32、构造函数
  • CentOS 系统安装 docker 以及常用插件
  • 介绍 Docker 的基本概念和优势,以及在应用程序开发中的实际应用。
  • mapbox基础,使用线类型geojson加载symbol符号图层,用于标注文字
  • 零信任架构实战手册-企业安全升级
  • 北师大发布《短视频家长指南》,回应短视频时代家庭教育挑战
  • 梅花奖在上海丨好戏在上海不缺观众,冷门剧种叫好又叫座
  • 住建部:目前已累计建设改造各类市政管网50万公里
  • 东南亚五大经济体一季度增长放缓,美国关税大棒或阻全年增长
  • 莱布雷希特专栏:古典乐坛边缘人
  • 墨西哥海军帆船纽约撞桥事故已致2人死亡19人受伤