SQL中EXISTS 代替 IN的一些情况

使用 IN
  • 当你使用 IN 子句时,SQL 会比较指定列的每个值是否包含在 IN 之后的列表中。
  • 如果列表中的值很多,或者子查询返回的结果集很大,那么 IN 子句的效率可能会很低。
  • 另外,如果列表中包含 NULL 值IN 子句在逻辑上会更加复杂,因为 NULL 与任何值的比较都是未知的(即不是真也不是假)。
使用 EXISTS
  • EXISTS 子句用于测试子查询是否返回了任何行。
  • 当使用 EXISTS 时,一旦找到符合条件的行,子查询就会停止处理,因为它不需要知道有多少行符合条件,只需要知道至少有一行符合条件。
  • 这意味着 EXISTS 通常在子查询可能返回大量结果时更有效率。
EXISTS 与 NULL 值
  • 当你的查询涉及到 NULL 值时,使用 EXISTS 可能更合适,因为 EXISTS 只关心是否存在符合条件的行,而不是实际的列值。
  • 如果子查询中的列存在 NULL 值,使用 IN 可能会导致不准确或者不符合预期的结果,因为 NULL 不能与其他值进行等值比较。
  • EXISTS 不直接与列值比较,而是基于行的存在性来返回真或假,因此它不受 NULL 值的影响。
示例

   假设我们有两个表:orders(订单表)和 customers(客户表),我们想要查找至少有一个订单的所有客户。

使用 IN 子句:

SELECT * FROM customers WHERE id IN (SELECT customer_id FROM orders);

   如果 orders 表中的 customer_id 列包含 NULL 值,那么这个 NULL 会在比较中被忽略,因为 NULL 与任何值的比较都不会返回真。

使用 EXISTS 子句:

SELECT * FROM customers c WHERE EXISTS (SELECT 1 FROM orders o WHERE o.customer_id = c.id);

   这里,一旦找到至少一个存在的订单,对应的 EXISTS 子句就会返回真,而且不关心 orders 表中的 customer_id 是否包含 NULL 值。

总结来说,当查询涉及到可能有 NULL 值的列时,使用 EXISTS 通常比 IN 更安全且效率更高。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/731045.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue 项目性能优化指南:提升应用速度与效率

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…

基于ACM32 MCU的胎压监测仪方案介绍,提高驾驶安全性

胎压监测仪设计方案 基于ACM32F070的胎压监测仪是一种智能化的汽车安全装置,它可以实时监测汽车轮胎的胎压,提高驾驶安全性,降低事故风险。该方案采用ACM32F070微控制器作为核心控制芯片,结合压力传感器、无线通信模块等外围设备&…

Javaweb day13 day14 day15

spring boot 快速入门 写法 http协议 请求协议 响应协议 协议解析 Tomcat

学习人工智能:吴恩达《AI for everyone》2019 第4周:歧视,攻击,发展中国家,就业

吴恩达 Andrew Ng, 斯坦福大学前教授,Google Brain项目发起人、领导者。 Coursera 的联合创始人和联合主席,在 Coursera 上有十万用户的《机器学习》课程;斯坦福大学计算机科学前教授。百度前副总裁、前首席科学家;谷…

机器学习开源分子生成系列(1)-DeepFrag的本地部署及使用

欢迎浏览我的CSND博客! Blockbuater_drug …进入 文章目录 前言一、DeepFrag是什么?二、conda中安装DeepFrag CLI环境1. 创建环境并激活2. 下载pre-trained model3. DeepFrag CLI 使用方法必需参数:可选参数: 4. DeepFrag CLI 使用…

了解开源可视化表单的主要优势

为什么可视化表单深受大家喜爱?这就需要了解开源可视化表单的优势和特点了。在流程化办公深入人心的今天,提高办公协作效率早已成为大家的发展目标,低代码技术平台、开源可视化表单是提升办公协作效率的得力助手,一起来看看它的优…

windows关闭copilot预览版

如果用户不想在windows系统当中启用Copilot,可以通过以下三种方式禁用。 第一种:隐藏Copilot 按钮 右键点击任务栏,取消勾选“显示 Copilot(预览版)按钮”,任务栏则不再显示,用户可以通过快捷键…

换手机后日记不见了怎么恢复?换手机日记内容同步方法

曾经,我使用的是一款苹果手机,这部手机陪伴了我整整3年。随着时间的推移,手机内存不够用成为了我面临的一个大问题,因此我决定更换一部新手机——这次我选择了OPPO品牌。在更换手机的过程中,我利用手机搬家软件一键同步…

Leetcode3070. 元素和小于等于 k 的子矩阵的数目

Every day a Leetcode 题目来源:3070. 元素和小于等于 k 的子矩阵的数目 解法1:二维前缀和 二维前缀和的模板题。 代码: /** lc appleetcode.cn id3070 langcpp** [3070] 元素和小于等于 k 的子矩阵的数目*/// lc codestart// 二维前缀和…

Python编程实验六:面向对象应用

目录 一、实验目的与要求 二、实验内容 三、主要程序清单和程序运行结果 第1题 第2题 四、实验结果分析与体会 一、实验目的与要求 (1)通过本次实验,学生应掌握类的定义与对象的创建、类的继承与方法的覆盖; (2…

守护Web安全:了解Web攻击与防护策略

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…

环境多介质逸度模型在污染物评估中的实践技术与代码示例

随着现代工业化的快速发展,污染物在环境中的迁移与转化日益受到人们的关注。多介质污染物模型,作为研究污染物在不同介质间迁移转化的重要工具,近年来受到了广泛的关注与研究。在众多多介质模型中,基于逸度概念的逸度模型因其广泛…

MKS真空规740B-742B-840B-852B-R700说明详细内容查看目录和图片目录

MKS真空规740B-742B-840B-852B-R700说明详细内容查看目录和图片目录

[数据集][目标检测]野生动物检测数据集VOC+YOLO格式1054张4类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):1504 标注数量(xml文件个数):1504 标注数量(txt文件个数):1504 标注…

HBase安装,配置,启动,检查

目录: 一、HBase安装,配置 1、下载HBase安装包 2、解压,配置环境变量并激活 3、hbase 配置 4、将hadoop和zookeeper的配置文件创建软连接放在hbase配置目录 5、配置 regionserver 二、HBase启动与关闭,安装检验 1、启动关闭hbase的命令 2、 检…

基于PHP的音乐网站后台管理系统设计与实现

目 录 摘 要 I Abstract II 引 言 3 1 相关技术 5 1.1 PHP技术 5 1.2 MySQL技术 5 1.3ThinkPHP框架 5 1.4 Apache技术 6 1.5 本章小结 6 2系统分析 7 2.1 功能需求 7 2.2 用例分析 7 2.3系统可行性分析 9 2.4 本章小结 10 3 系统设计 11 3.1 总体设计 11 3.2 数据库设计 12 3.…

IPSEC VPPN实验

实验背景:FW1和FW2是双机热备的状态。 实验要求:在FW和FW3之间建立一条IPSEC通道,保证10.0.2.0/24网段可以正常访问到192.168.1.0/24 IPSEC VPPN实验配置(由于是双机热备状态,所以FW1和FW2只需要配置FW1主设备即可&…

linux ipmitool - 硬件管理软件

1、简介 ipmitool 是一款开源的命令行工具,用于管理远程服务器的硬件,可以通过 IPMI(Intelligent Platform Management Interface)接口与服务器进行通信。它可以帮助管理员监视服务器的状态、诊断硬件问题、重置服务器、更新固件…

R语言中ggplot2图例位置、颜色、背景、标题

目录 1、不显示图例 2、自定义图例位置 3、修改图例背景颜色、外框颜色、大小 4、修改图例大小 5、图例设置背景、线框为空 6、自定义设置多个图例的标题 7、设置多个图例的之间的间隔 8、取消不需要的图例显示 1、不显示图例 theme(legend.position "none"…

YOLOX论文解读

paper:YOLOX: Exceeding YOLO Series in 2021 official implementation:https://github.com/Megvii-BaseDetection/YOLOX 本文的创新点 本文在YOLOv3的基础上进行了一些改进:包括将检测头进行解耦的decoupled head、从anchor-based转为anc…