场景还原

有一个字段是 已删除 deleted

如果0 则是未删除

如果1 则是已删除

我写的where条件是 deleted != 1

然后数据库里面这个字段的值都是null

我当时就想,null值,也就是不等于1,没毛病,但是就是查不出来,于是我问了一下通义千问,回答如下:

AI回答

理解你的困惑,但实际上在 SQL 中,NULL 的处理方式不同于普通的值。在 SQL 中,NULL 表示“未知”或“不存在”,因此任何与 NULL 的比较都会返回 NULL,而不是 TRUEFALSE。这意味着 NULL != 1 的结果是 NULL,而不是 TRUE

解释

在 SQL 中,以下表达式的结果如下:

  • NULL = 1 结果是 NULL
  • NULL != 1 结果是 NULL
  • NULL IS NULL 结果是 TRUE
  • NULL IS NOT NULL 结果是 FALSE

因此,如果你的查询条件是 deleted != 1,那么 deletedNULL 的记录会被排除在外,因为 NULL != 1 的结果是 NULL,而不是 TRUE

解决方案

为了确保 deletedNULL 的记录也能被查询到,你需要使用 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

总结

通过修改查询条件,确保 deletedNULL 的记录也能被正确查询到。希望这能解决你的问题。

[SQL]null值被比较的结果问题的更多相关文章

  1. SQL NULL 值【摘自W3C】

    SQL NULL 值 本章讲解 IS NULL 和 IS NOT NULL 操作符. NULL 值是遗漏的未知数据.默认地,表的列可以存放 NULL 值. 如果表中的某个列是可选的,那么我们可以在不向 ...

  2. SQL NULL 值

    NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS NOT NULL 操作符. SQL NULL 值 如果表中的某个列是可选的,那么我们可以在不 ...

  3. SQL-W3School-高级:SQL NULL 值

    ylbtech-SQL-W3School-高级:SQL NULL 值 1.返回顶部 1. NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS N ...

  4. sql null值

    SQL Server 提供 SET CONCAT_NULL_YIELDS_NULL { ON | OFF } 来控制 null 与其它字符串连接的行为. 当 SET CONCAT_NULL_YIELD ...

  5. SQL null值 查询null

    select * from emp;

  6. 22.NULL 值

    NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS NOT NULL 操作符. SQL NULL 值 如果表中的某个列是可选的,那么我们可以在不 ...

  7. SQL中NULL值

    SQL的表达式,除了IS NULL和NOT NULL以外,只要出现NULL值结果都为FALSE 简单的例子: SELECT * FROM table WHERE name!='abc' 只要name值 ...

  8. SQL Server表分区的NULL值问题

    SQL Server表分区的NULL值问题 SQL Server表分区只支持range分区这一种类型,但是本人觉得已经够用了 虽然MySQL支持四种分区类型:RANGE分区.LIST分区.HASH分区 ...

  9. SQL SERVER使用ODBC 驱动建立的链接服务器调用存储过程时参数不能为NULL值

    我们知道SQL SERVER建立链接服务器(Linked Server)可以选择的驱动程序非常多,最近发现使用ODBC 的 Microsoft OLE DB 驱动程序建立的链接服务器(Linked S ...

  10. mysql,sql server,oracle 唯一索引字段是否允许出现多个 null 值?

    最近一个项目,涉及到sql server 2008,因为业务需求,希望建立一个唯一索引,但是发现在sql server中,唯一索引字段不能出现多个null值,下面是报错信息: CREATE UNIQU ...

随机推荐

  1. 1. 什么是three.js?

    Three.js是一个基于JavaScript编写的开源3D图形库,它使用WebGL技术在网页上渲染3D图形.Three.js提供了许多高级功能,如几何体.纹理.光照.阴影等,以便开发者能够快速地创建 ...

  2. C# 中的四种整形数据

    // C# 中有四种整数类型 byte short int long byte bMax = byte.MaxValue; /// 255 最大值 byte bMin = byte.MinValue; ...

  3. 在实例化对象的时候new关键字具体做了哪些操作?

    a 创建了一个空对象 {}b 通过原型链把空对象和构造函数连接起来__proto__ = prototype c 构造函数的this指向新对象,并执行函数体 d 判断构造函数的返回值,返回对象就使用该 ...

  4. 3. 用过Konva吗,用过他的api吗

    基础:使用konva,首先需要创建舞台也就是stage,然后创建一个Layer图层,将图层放到舞台上,将图形等内容放到图层上 ; 第一步:创建一个Stage舞台  , 就是创建一个 stage 实例 ...

  5. apache安装详解

    Apache安装 准备工作. 首先在C盘根目录下创建一个名为web的文件夹作为php开发环境的安装位置,并在web文件夹中创建apache24子文件夹,将apache解压后文件放至此处. 安装包 首先 ...

  6. KubeSphere 社区双周报 | KubeSphere 多项更新 | 2023.06.23-07.06

    KubeSphere 社区双周报主要整理展示新增的贡献者名单和证书.新增的讲师证书以及两周内提交过 commit 的贡献者,并对近期重要的 PR 进行解析,同时还包含了线上/线下活动和布道推广等一系列 ...

  7. 在 KubeSphere 中部署高可用 Redis 集群

    作者:余生大大,大数据开发工程师,云原生爱好者,KubeSphere 社区用户. 前言 Redis 是在开发过程中经常用到的缓存中间件,在生产环境中为了考虑稳定性和高可用一般为集群模式的部署. 常规部 ...

  8. Vue最受欢迎的七大跨端框架,你都用过哪几个?

    随着移动互联网的快速发展,开发者们不仅需要为Web开发,还需要兼顾iOS.Android.小程序等多个平台.这让"跨端开发"成为了炙手可热的话题.而基于Vue的跨端框架凭借其优异的 ...

  9. .NET云原生应用实践(三):连接到PostgreSQL数据库

    本章目标 实现基于PostgreSQL的SDAC(简单数据访问层) 将Stickers微服务切换到使用PostgreSQL SDAC 为什么选择PostgreSQL数据库? 其实并不一定要选择Post ...

  10. 批处理-- 查询进程,杀进程,启动pythond程序,任务计划程序

    @echo off wmic process where caption="python.exe" get processid,commandline | findstr &quo ...