面试官:MySQL中<>能过滤到null值吗?

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 引言了不起最近在定位一个bug的时候,发现本应该过滤出15355条数据的,但其实只过滤出了12891条数据。然后我就把sql找出来,根据debug调试的参数取到,一执行,果然结果只有12891。代码大概就像这样的:List<OrderAllotPackage> orderAllotPackageList = orderAllotPackageService.lambdaQuery() .ne(OrderAllotPackage::getTrackingNumber, "") .ne(OrderAllo

引言

了不起最近在定位一个bug的时候,发现本应该过滤出15355条数据的,但其实只过滤出了12891条数据。

然后我就把sql找出来,根据debug调试的参数取到,一执行,果然结果只有12891。

代码大概就像这样的:

List<OrderAllotPackage> orderAllotPackageList = orderAllotPackageService.lambdaQuery()
                    .ne(OrderAllotPackage::getTrackingNumber, "")
                    .ne(OrderAllotPackage::getFulfillmentStatus, PackageFulfillStatus.DELETED.getValue())
                    .ne(OrderAllotPackage::getFulfillmentStatus, PackageFulfillStatus.CANCELLED.getValue())
                    .ne(OrderAllotPackage::getFulfillmentStatus, PackageFulfillStatus.EXCEPTION.getValue())
                    .ne(OrderAllotPackage::getPackageNo, "")
                    .ne(OrderAllotPackage::getNStatus, "EXCEPTION")
                    .ne(OrderAllotPackage::getNStatus, "FULFILLED")
                    .ne(OrderAllotPackage::getNStatus, "SHIPPED")
//                    .eq(OrderAllotPackage::getNStatus, "")
                    .list();

更多细节我也不贴了,主要就是这个sql。

于是乎开始了sql一扒拉过滤条件分析,逐个删除和增加条件,排查是哪个过滤条件造成的问题。

我这里就先卖个关子,你们想一下 <> 能过滤到某个字段值为空的情况吗。

MySQL中不等于

我们在做业务筛选时,比如条件特别多的,我们只要排查某一种情况就可以用不等于。

在MySQL中,不等于的操作符是 <>!=,可以用于比较两个值是否不相等。

以下是使用这些操作符进行不等于比较的示例:

SELECT*FROM table_name WHERE column_name <>'value';
SELECT*FROM table_name WHERE column_name !='value';

在上述示例中,table_name是表名,column_name是要比较的列名,value是要与该列进行比较的值。

这将返回满足不等于条件的行。

建表实操

创建数据库表

CREATE TABLE test_user (
  id INT PRIMARY KEY,
  name VARCHAR(255),
  age INT,
  hobby VARCHAR(255)
);

插入数据

INSERT INTO test_user (id, name, age, hobby)
VALUES (1, 'John', 25, 'Reading'),
       (2, 'Jane', 30, 'Sports'),
       (3, 'Jake', 35, NULL);

注意我这里故意插入了一个字段值为null的数据。

执行结果

我们来查询一下:

SELECT * from test_user where hobby <> ' '

SELECT * from test_user where hobby <> 'Sports'

问题反思

想必大家看了,心里都有了答案,MySQL中的不等于会排除掉字段值为null的情况。

1. 什么场景下使用不等于

  • 过滤掉特定值:当我们需要排除某些特定值时,例如,筛选出不是特定分类条件下的数据
  • 比较范围之外的值:如果我们要查找某个范围之外的数据,不等于操作符可以用于排除该范围内的值。

2. 使用不等于有没有什么必要条件

使用不等于操作符的必要条件取决于具体的查询需求。

如果我们需要排除特定值或比较范围之外的值,那么使用不等于操作符是有必要的。

然而,在某些情况下,可以使用其他操作符或条件语句来实现相同的效果,这取决于查询的逻辑和数据的特点。

一句话:视情况而定,没有什么是必要的。

3. 为了代码简单使用不等于未考虑字段值为Null的情况带来的影响

在MySQL中使用不等于操作符(<>)会排除掉字段值为 NULL的情况。

这是因为在MySQL中,NULL代表缺失或未知的值,与其他值的比较结果通常是未知的。

因此,使用不等于操作符时,我们需要注意是否希望包含或排除 NULL值,确保查询的准确性,而这一点在数据库设计初期和编码的时候都要去看下这个字段值的范围。

4. 可以少使用不等于

为了避免不等于操作符可能带来的问题,可以考虑以下建议,尽量减少使用不等于操作符:

  • 使用其他操作符:根据具体需求,考虑使用等于操作符、范围操作符(例如 BETWEEN)、IN操作符等来替代不等于操作符。
  • 使用 IS NULLIS NOT NULL:如果需要针对 NULL值进行比较,可以使用 IS NULLIS NOT NULL来明确处理 NULL值的情况。
  • 使用逻辑操作符:在复杂的查询中,使用逻辑操作符(例如 ANDOR)可以更灵活地组合多个条件,避免过度依赖不等于操作符。

总结

今天了不起带着大家看了一个MySQL中不等于的实际使用,相信没用过的你也学会了,即将要用到的也希望后面能注意到这个问题。

具体使用还是不使用不等于根据业务情况来做取舍,没有什么是绝对的。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
21天前
|
存储 关系型数据库 MySQL
【Java面试题汇总】MySQL数据库篇(2023版)
聚簇索引和非聚簇索引、索引的底层数据结构、B树和B+树、MySQL为什么不用红黑树而用B+树、数据库引擎有哪些、InnoDB的MVCC、乐观锁和悲观锁、ACID、事务隔离级别、MySQL主从同步、MySQL调优
【Java面试题汇总】MySQL数据库篇(2023版)
|
2月前
|
SQL 存储 关系型数据库
复盘女朋友面试4个月的Mysql面试题(1万字)
该文章详细分析了Ribbon的超时配置是否会覆盖OpenFeign的超时配置,并探讨了OpenFeign超时配置能否动态实时修改生效的问题。
复盘女朋友面试4个月的Mysql面试题(1万字)
|
2月前
|
关系型数据库 MySQL Java
面试官:说说MySQL调优?
面试官:说说MySQL调优?
71 5
面试官:说说MySQL调优?
|
2月前
|
SQL 关系型数据库 MySQL
面试准备-MySQL
面试准备-MySQL
|
2月前
|
缓存 NoSQL Redis
一天五道Java面试题----第九天(简述MySQL中索引类型对数据库的性能的影响--------->缓存雪崩、缓存穿透、缓存击穿)
这篇文章是关于Java面试中可能会遇到的五个问题,包括MySQL索引类型及其对数据库性能的影响、Redis的RDB和AOF持久化机制、Redis的过期键删除策略、Redis的单线程模型为何高效,以及缓存雪崩、缓存穿透和缓存击穿的概念及其解决方案。
|
2月前
|
算法 关系型数据库 MySQL
一天五道Java面试题----第七天(mysql索引结构,各自的优劣--------->事务的基本特性和隔离级别)
这篇文章是关于MySQL的面试题总结,包括索引结构的优劣、索引设计原则、MySQL锁的类型、执行计划的解读以及事务的基本特性和隔离级别。
|
2月前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 IS NULL
【8月更文挑战第12天】
591 0
在 MySQL 中使用 IS NULL
|
2月前
|
存储 关系型数据库 MySQL
MySQL 常见面试题总结(上)
主要介绍 MYSQL 数据库面试中常见的面试问题。
23 0
|
2月前
|
SQL 关系型数据库 MySQL
mysql不等于<>取特定值反向条件的时候字段有null值或空值读取不到数据
对于数据库开发的专业人士来说,理解NULL的特性并知道如何正确地在查询中处理它们是非常重要的。以上所介绍的技巧和实例可以帮助你更精准地执行数据库查询,并确保数据的完整性和准确性。在编写代码和设计数据库结构时,牢记这些细节将有助于你避免许多常见的错误,提高数据库应用的质量与性能。
50 0
|
18天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
下一篇
无影云桌面