[SQL]null值被比较的结果问题
场景还原
有一个字段是 已删除 deleted
如果0 则是未删除
如果1 则是已删除
我写的where条件是 deleted != 1
然后数据库里面这个字段的值都是null
我当时就想,null值,也就是不等于1,没毛病,但是就是查不出来,于是我问了一下通义千问,回答如下:
AI回答
理解你的困惑,但实际上在 SQL 中,NULL 的处理方式不同于普通的值。在 SQL 中,NULL 表示“未知”或“不存在”,因此任何与 NULL 的比较都会返回 NULL,而不是 TRUE 或 FALSE。这意味着 NULL != 1 的结果是 NULL,而不是 TRUE。
解释
在 SQL 中,以下表达式的结果如下:
NULL = 1结果是NULLNULL != 1结果是NULLNULL IS NULL结果是TRUENULL IS NOT NULL结果是FALSE
因此,如果你的查询条件是 deleted != 1,那么 deleted 为 NULL 的记录会被排除在外,因为 NULL != 1 的结果是 NULL,而不是 TRUE。
解决方案
为了确保 deleted 为 NULL 的记录也能被查询到,你需要使用 IS NULL 条件来处理 NULL 值。具体来说,可以将 deleted != 1 修改为 deleted != 1 OR deleted IS NULL。
修改后的 SQL 查询
SELECT *
FROM menu_data_item
WHERE (deleted != 1 OR deleted IS NULL)
AND id IN (
SELECT system_role_menu.menu_id
FROM system_role_menu
WHERE role_id = 'root'
)
示例
假设你有以下数据:
| id | title | icon | path | component | redirect | affix | parent_id | name | hide_in_menu | url | hide_in_breadcrumb | hide_children_in_menu | keep_alive | target | locale | deleted |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 001 | 首页 | DashboardOutlined | /dashboard | RouteView | /dashboard/analysis | 0 | NULL | Dashboard | 0 | NULL | 0 | 0 | 0 | NULL | menu.dashboard | NULL |
| 100 | 系统设置 | BarsOutlined | /system | RouteView | /system/user | NULL | NULL | System | NULL | NULL | NULL | NULL | NULL | NULL | menu.system | NULL |
| 101 | 用户管理 | BarsOutlined | /system/user | /system/user | NULL | NULL | 100 | SystemUserManage | NULL | NULL | NULL | NULL | 1 | NULL | menu.system.user | NULL |
| 102 | 菜单管理 | BarsOutlined | /system/menu | /system/menu | NULL | NULL | 100 | SystemMenuManage | NULL | NULL | NULL | NULL | 1 | NULL | menu.system.menu | NULL |
| 020 | 数据中心 | DashboardOutlined | /dashboard/analysis | /dashboard/analysis | NULL | 0 | 001 | DashboardAnalysis | 0 | NULL | 0 | 0 | 1 | NULL | menu.dashboard.analysis | NULL |
运行修改后的查询:
SELECT *
FROM menu_data_item
WHERE (deleted != 1 OR deleted IS NULL)
AND id IN (
SELECT system_role_menu.menu_id
FROM system_role_menu
WHERE role_id = 'root'
)
预期结果:
| id | title | icon | path | component | redirect | affix | parent_id | name | hide_in_menu | url | hide_in_breadcrumb | hide_children_in_menu | keep_alive | target | locale | deleted |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 001 | 首页 | DashboardOutlined | /dashboard | RouteView | /dashboard/analysis | 0 | NULL | Dashboard | 0 | NULL | 0 | 0 | 0 | NULL | menu.dashboard | NULL |
| 100 | 系统设置 | BarsOutlined | /system | RouteView | /system/user | NULL | NULL | System | NULL | NULL | NULL | NULL | NULL | NULL | menu.system | NULL |
| 101 | 用户管理 | BarsOutlined | /system/user | /system/user | NULL | NULL | 100 | SystemUserManage | NULL | NULL | NULL | NULL | 1 | NULL | menu.system.user | NULL |
| 102 | 菜单管理 | BarsOutlined | /system/menu | /system/menu | NULL | NULL | 100 | SystemMenuManage | NULL | NULL | NULL | NULL | 1 | NULL | menu.system.menu | NULL |
| 020 | 数据中心 | DashboardOutlined | /dashboard/analysis | /dashboard/analysis | NULL | 0 | 001 | DashboardAnalysis | 0 | NULL | 0 | 0 | 1 | NULL | menu.dashboard.analysis | NULL |
总结
通过修改查询条件,确保 deleted 为 NULL 的记录也能被正确查询到。希望这能解决你的问题。
[SQL]null值被比较的结果问题的更多相关文章
- SQL NULL 值【摘自W3C】
SQL NULL 值 本章讲解 IS NULL 和 IS NOT NULL 操作符. NULL 值是遗漏的未知数据.默认地,表的列可以存放 NULL 值. 如果表中的某个列是可选的,那么我们可以在不向 ...
- SQL NULL 值
NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS NOT NULL 操作符. SQL NULL 值 如果表中的某个列是可选的,那么我们可以在不 ...
- SQL-W3School-高级:SQL NULL 值
ylbtech-SQL-W3School-高级:SQL NULL 值 1.返回顶部 1. NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS N ...
- sql null值
SQL Server 提供 SET CONCAT_NULL_YIELDS_NULL { ON | OFF } 来控制 null 与其它字符串连接的行为. 当 SET CONCAT_NULL_YIELD ...
- SQL null值 查询null
select * from emp;
- 22.NULL 值
NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS NOT NULL 操作符. SQL NULL 值 如果表中的某个列是可选的,那么我们可以在不 ...
- SQL中NULL值
SQL的表达式,除了IS NULL和NOT NULL以外,只要出现NULL值结果都为FALSE 简单的例子: SELECT * FROM table WHERE name!='abc' 只要name值 ...
- SQL Server表分区的NULL值问题
SQL Server表分区的NULL值问题 SQL Server表分区只支持range分区这一种类型,但是本人觉得已经够用了 虽然MySQL支持四种分区类型:RANGE分区.LIST分区.HASH分区 ...
- SQL SERVER使用ODBC 驱动建立的链接服务器调用存储过程时参数不能为NULL值
我们知道SQL SERVER建立链接服务器(Linked Server)可以选择的驱动程序非常多,最近发现使用ODBC 的 Microsoft OLE DB 驱动程序建立的链接服务器(Linked S ...
- mysql,sql server,oracle 唯一索引字段是否允许出现多个 null 值?
最近一个项目,涉及到sql server 2008,因为业务需求,希望建立一个唯一索引,但是发现在sql server中,唯一索引字段不能出现多个null值,下面是报错信息: CREATE UNIQU ...
随机推荐
- 《Vue.js 设计与实现》读书笔记 - 第10章、双端 Diff 算法
第10章.双端 Diff 算法 10.1 双端比较的原理 上一章的移动算法并不是最优的,比如我们把 ABC 移动为 CAB,如下 A C B --> A C B 按照上一章的算法,我们遍历新的数 ...
- MQ核心作用异步&削峰&解耦使用场景详解
说在前面 在如今的高并发互联网应用中,如何确保系统在巨大的流量冲击下还能稳稳当当运转,是每个技术团队都会遇到的挑战.说到这,消息队列(MQ) 就是背后的"大功臣"了. 无论是异步处 ...
- sqlSugar 使用原生模式链接数据库
using System.Reflection; using zhulongxu_webapi_pro.Tools; namespace zhulongxu_webapi_pro.Services { ...
- 简述 JavaScript脚本的执行原理?
js 是一种动态 . 弱类型 . 基于原型的语言 ,通过浏览器可以直接执行: 当浏览器遇到 <script></script>标记时 , 会执行标记之间的js 代码:然后js ...
- js实现控制音乐播放
js实现控制音乐播放 用js实现控制音乐播放其实很简单,但是第一次去做可能会遇到一点点小问题. 比如说我自己,第一次想实现一个播放器效果,然后在网上搜寻半天照着自己的理解写下如下代码: <!D ...
- DirectoryOpus插件:“照得标管理器”-海量照片分类管理好帮手!
照得标管理器 前言 名词解释:"照得标管理器",即:照片得到标签管理器,后文统一简称"照得标管理器"或"照得标". 注:请不要和抖 ...
- 在 Kubernetes 中基于 StatefulSet 部署 MySQL(上)
大家好,我是老 Z! 本文实现了 MySQL 数据库在基于 KubeSphere 部署的 K8s 集群上的安装部署,部署方式采用了图形化这种形式.下一篇文章将会涉及 GitOps 的基础操作,部署过程 ...
- snap和apt的区别简单了解[]
Linux中没有tree命令的时候提示安装的时候出现了两个命令,简单看了看两者有何区别(一般用apt就可以了): sudo snap install tree 和 sudo apt install ...
- 万星开源项目:System Design Primer - 学习系统设计的必备指南
GitHub 链接:https://github.com/donnemartin/system-design-primer 什么是 System Design Primer? System Desig ...
- Matlab矩阵运算的硬件资源分析
在用Matlab创建矩阵并计算矩阵乘法运算时,要注意计算机的可用内存大小(空间资源)和CPU性能(影响所用计算时间). 例如我们做以下测试:n为qubit的数目,那么一个矩阵Matrix_A=rand ...