【MySQL】not in遇上null的坑
今天遇到一个问题:
1、当 in 内的字段包含 null 的时候,正常过滤;
2、当 not in 内的字段包含 null 的时候,不能正常过滤,即使满足条件,最终结果也为 空。
测试如下:
select * from emp e;

当 in 内的字段包含 null 的时候,结果正常:
select * from emp e where e.mgr in (select comm from emp t);

当 not in 内的字段包含 null 的时候,结果为空,实际应为下面加上 is not null 条件时的结果才算正常:
select * from emp e where e.mgr not in (select comm from emp t);

加上 is not null 条件时,结果正常(由于NULL不等于NULL,也去除了 MGR 为 NULL 的那条记录,所以是12条):
select * from emp e where e.mgr not in (select comm from emp t where t.comm is not null);

根据以上测试,得出用 not in 条件过滤时应首先排除 is not null 的记录,否则可能会出现意想不到的结果。
其实,当not in中包含null
select * from t where class not in ('1','2',null)
上面的sql相当于:
select * from t where class !='1'and !='2'and !=null
在SQL中,NULL值与任何其它值的比较(即使是NULL)永远不会为“真”。not in 相当于and条件,只要有一个false,那么所有的都为false,所以查出来的数据固定为空
解决方案:not in中的数据过滤掉空值 或 使用not exists
exists用法
select * from 表A where id in (select id from 表B)-- 上面的sql可以改写为:
select * from 表A where exists(select 1 from 表B where 表B.id=表A.id)
in以子查询表B的结果集为驱动,在表A中依次遍历查询id是否在子查询的结果集中存在
exists以外表表A为驱动表,若括号内的子查询有任意数据返回,表示当前行匹配成功
exists用于检查子查询是否至少会返回一行数据,强调的是是否返回结果集,不要求知道返回什么
相关文章:
【MySQL】not in遇上null的坑
今天遇到一个问题: 1、当 in 内的字段包含 null 的时候,正常过滤; 2、当 not in 内的字段包含 null 的时候,不能正常过滤,即使满足条件,最终结果也为 空。 测试如下: select * from emp e;当…...
鸿蒙4.0-DevEco Studio界面工程
DevEco Studio界面工程 DevEco Studio 下载与第一个工程新建的第一个工程界面回到Project工程结构来看 DevEco Studio 下载与第一个工程 DevEco Studio 下载地址:点击跳转 https://developer.harmonyos.com/cn/develop/deveco-studio#download 学习课堂以及文档地址…...
前端将html导出pdf文件解决分页问题
这是借鉴了qq_251025116大佬的解决方案并优化升级完成的,原文链接 1.安装依赖 npm install jspdf html2canvas2.使用方法 import htmlToPdffrom ./index.jsconst suc () > {message.success(success);};//记得在需要打印的div上面添加 idlet dom document.que…...
openssl3.2 - exp - 产生随机数
文章目录 openssl3.2 - exp - 产生随机数概述笔记END openssl3.2 - exp - 产生随机数 概述 要用到openssl产生的随机数, 查了资料. 如果用命令行产生随机数, 如下: openssl rand -hex -num 6 48bfd3a64f54单步跟进去, 看到主要就是调用了一个RAND_bytes(), 没其他了. 官方说…...
【三两波折】char *foo[]和char(*foo)[]有何不同?
1、先谈优先级 最高级别 —— 有四个,他们并不像运算符: []数组下标左到右结合()用于(表达式) or 函数名(形参表)左到右结合.读取结构体成员左到右结合->读取结构体成员(通过指针)左到右结合 第二级别…...
k8s(kubernetes)怎么查看pod服务对应哪些docker容器
Kubernetes(k8s)中的Pod是一组共享网络和存储资源的容器集合。每个Pod都包含一个或多个Docker容器,这些容器共享网络命名空间和存储卷,并在同一主机上运行。因此,可以将Pod视为一组紧密相关的Docker容器的逻辑主机&…...
[2023年]-hadoop面试真题(二)
[2023年]-hadoop面试真题(一) (北京) Maptask的个数由什么决定?(北京) 如何判定一个job的map和reduce的数量 ?(北京) MR中Shuffle过程 ?(北京) MR中处理数据流程 ?(…...
蓝桥杯备战刷题-滑动窗口
今天给大家带来的是滑动窗口的类型题,都是十分经典的。 1,无重复字符的最长子串 看例三,我们顺便来说一下子串和子序列的含义 子串是从字符串里面抽出来的一部分,不可以有间隔,顺序也不能打乱。 子序列也是从字符串里…...
LLM(十一)| Claude 3:Anthropic发布最新超越GPT-4大模型
2024年3月4日,Anthropic发布最新多模态大模型:Claude 3系列,共有Haiku、Sonnet和Opus三个版本。 Opus在研究生水平专家推理、基础数学、本科水平专家知识、代码等10个维度,超过OpenAI的GPT-4。 Haiku模型更注重效率,能…...
20-Java备忘录模式 ( Memento Pattern )
Java备忘录模式 摘要实现范例 备忘录模式(Memento Pattern)保存一个对象的某个状态,以便在适当的时候恢复对象 备忘录模式属于行为型模式 摘要 1. 意图 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对…...
整合生成型AI战略:从宏观思维到小步实践
“整合生成型AI战略:从宏观思维到小步实践” 在这篇文章中,我们探讨了将生成型AI和大型语言模型融入企业核心业务的战略开发方法。我们的方法基于敏捷开发原则,技术专家和数据科学家需要采纳商业思维,而执行官则需理解生成型AI和…...
个人博客系列-后端项目-用户验证(5)
介绍 创建系统管理app,用于管理系统的用户,角色,权限,登录等功能,项目中将使用django-rest_framework进行用户认证和权限解析。这里将完成用户认证 用户验证 rest_framework.authentication模块中的认证类ÿ…...
css3中nth-child属性作用及用法剖析
hello宝子们...我们是艾斯视觉擅长ui设计和前端开发10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 标题:CSS3中nth-child属性作用及用法剖析 摘要:CSS3中的nth-child选择器允许我们根据元素位置来定位特定的元素…...
okHttp MediaType MIME格式详解
一、介绍 我们在做数据上传时,经常会用到Okhttp的开源库,okhttp开源库也遵循html提交的MIME数据格式。 所以我们经常会看到applicaiton/json这样的格式在传。 但是如果涉及到其他文件等就需要详细的数据格式,否则服务端无法解析 二、okHt…...
跨境电商三大趋势
跨境电商有着不断发展的三大趋势: 个性化定制:随着消费者需求的不断变化和个性化定制的潮流,跨境电商平台开始提供更多的定制化服务。消费者可以根据自己的需求选择产品的款式、材料和设计,从而获得更加个性化的产品体验。 无界销…...
【DevOps基础篇之k8s】如何通过Kubernetes CKA认证考试
【DevOps基础篇之k8s】如何通过Kubernetes CKA认证考试 目录 【DevOps基础篇之k8s】如何通过Kubernetes CKA认证考试核心概念资源监控生命周期管理Cluster维护安全认证问题排查其他推荐超级课程: Docker快速入门到精通Kubernetes入门到大师通关课这些是我在准备CK...
Mysql数据库-基本表操作
1.表操作 创建表:CREATE TABLE table_name ( field1 datatype, field2 datatype, field3 datatype ) character set 字符集 collate 校验规则 engine 存储引擎; field 表示列名 datatype 表示列的类型 character set 字符集,如果没有指定字符集ÿ…...
OceanBase社区版单节点安装搭建(Docker)
OceanBase社区版单节点安装搭建(Docker) 文章目录 OceanBase社区版单节点安装搭建(Docker)一、环境检查及Docker配置1.1 安装docker1.2 配置docker镜像源 二、OB镜像下载三、obd部署单节点数据库四、创建业务租户、数据库、表4.1 …...
Unity 关节:铰链、弹簧、固定、物理材质:摩檫力、 特效:拖尾、
组件-物理-关节:铰链(类似门轴) 自动动作、多少力可以将其断开、 弹簧可以连接另一个刚体(拖动即可) 固定一般是等待一个断裂力,造成四分五裂的效果。 物理材质 设置摩檫力,则可以创造冰面的…...
RIPEMD算法:多功能哈希算法的瑰宝
title: RIPEMD算法:多功能哈希算法的瑰宝 date: 2024/3/10 17:31:17 updated: 2024/3/10 17:31:17 tags: RIPEMD起源算法优势安全风险对比SHA优于MD5应用领域工作原理 一、RIPEMD算法的起源与历程 RIPEMD(RACE Integrity Primitives Evaluation Messag…...
经典蓝牙协议:【A2DP,HSP/HFP,OBEX/OPP】—— 从协议栈到场景应用的深度解析
1. 蓝牙协议栈全景图:从音乐播放到文件传输 第一次接触蓝牙协议时,我盯着文档里密密麻麻的英文缩写直发懵——A2DP、HFP、OBEX这些字母组合看起来像某种密码。直到调试TWS耳机项目时,音乐卡顿和通话杂音的问题才让我明白:不同蓝牙…...
Scroll Reverser:终极解决方案!如何让Mac触控板和鼠标实现完美滚动和谐
Scroll Reverser:终极解决方案!如何让Mac触控板和鼠标实现完美滚动和谐 【免费下载链接】Scroll-Reverser Per-device scrolling prefs on macOS. 项目地址: https://gitcode.com/gh_mirrors/sc/Scroll-Reverser 你是否曾在MacBook触控板上享受自…...
stm32 freertos 学习尚硅谷 第 2 章FreeRTOS基础知识
多任务处理单核处理器一次只能执行一项任务。 多任务操作系统可以通过任务之间的快速切换制造并发执行的假象任务调度操作系统中任务调度器的责任就是决定在某一时刻要执行哪个任务。调度器是内核中负责决定在任何特定时间应执行哪些任务的部分。内核可以在任务生命周期内多次挂…...
K8s 1.36 新特性深度解析:服务网格与零信任集成(生产级配置)
K8s 1.36 新特性深度解析:服务网格与零信任集成(生产级配置) 前言:K8s 1.36 被称为“云原生安全网络里程碑”版本,核心突破集中在「服务网格原生化」和「零信任落地」两大板块——彻底解决了过去服务网格“资源占用高、…...
Windows任务栏透明美化终极指南:TranslucentTB完整配置教程
Windows任务栏透明美化终极指南:TranslucentTB完整配置教程 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB TranslucentTB是一…...
基于STM32的智能温控系统设计与物联网集成
1. 从零搭建智能温控系统的核心思路 第一次接触STM32温控项目时,我被各种专业术语搞得头晕眼花。后来发现只要抓住三个关键点:精准测温、智能调控、远程操控。就像给房间装空调,首先得知道当前温度(传感器),…...
Gartner Magic Quadrant for Data Center Switching 2025 | Gartner 数据中心交换魔力象限 2025
Gartner Magic Quadrant for Data Center Switching 2025 Gartner 魔力象限:数据中心网络交换机 2025 请访问原文链接:https://sysin.org/blog/gartner-magic-quadrant-data-center-switching-2025/ 查看最新版。原创作品,转载请保留出处。…...
自动化测试策略
自动化测试策略:提升效率与质量的关键 在软件开发过程中,测试是确保产品质量的重要环节。随着敏捷开发和DevOps的普及,传统的手工测试已无法满足快速迭代的需求,自动化测试策略因此成为提升效率与质量的关键。通过合理的自动化测…...
LeetCode hot 100 (12-16,自用2026.04.06)
LeetCode hot 100 (12-16,自用2026.04.06) 53. 最大子数组和 给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组是数组中的一个连续部分。 示例 1: 输入…...
RudderStack部署实战:从Docker到Kubernetes的完整指南
RudderStack部署实战:从Docker到Kubernetes的完整指南 【免费下载链接】rudder-server Privacy and Security focused Segment-alternative, in Golang and React 项目地址: https://gitcode.com/gh_mirrors/ru/rudder-server RudderStack是一款注重隐私与安…...
