”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > SQL 中的 NULL 处理

SQL 中的 NULL 处理

发布于2024-07-31
浏览:645

NULL Handling in SQL

介绍

在 SQL 中处理 NULL 值是每个数据库专业人员必须掌握的基本方面。 NULL 表示数据库表中缺失或未定义的值,正确处理这些值对于确保数据操作的完整性和准确性至关重要。本文将深入探讨 SQL 中 NULL 的概念、其含义以及处理 NULL 值的各种策略。

了解 SQL 中的 NULL

SQL中的NULL是一个特殊标记,用于指示数据库中不存在某个数据值。它不等于空字符串或零值。相反,NULL 表示不存在任何值。数据库表中 NULL 值的存在可能会影响查询结果,尤其是在执行比较、聚合和联接等操作时。

NULL 的主要特征

  1. 不确定值:NULL表示未知或不确定值。
  2. 非可比性:涉及 NULL 的比较(例如 =、)始终产生 NULL,而不是 TRUE 或 FALSE。
  3. 函数中的特殊处理:许多 SQL 函数在处理 NULL 值时都有特定的行为。

在 SQL 中使用 NULL

检查 NULL

要检查值是否为 NULL,请使用 IS NULL 或 IS NOT NULL 运算符。例如:

SELECT * FROM employees WHERE manager_id IS NULL;

此查询检索没有经理的所有员工。

NULL 和比较运算符

使用标准比较运算符(=、!=、

SELECT * FROM employees WHERE manager_id = NULL;

此查询不会返回任何行,即使某些 manager_id 值为 NULL。相反,您应该使用:

SELECT * FROM employees WHERE manager_id IS NULL;

聚合中的 NULL

SUM、AVG、COUNT 等聚合函数对 NULL 值的处理方式不同。例如,SUM 和 AVG 忽略 NULL 值,而 COUNT 可以在明确指定的情况下对它们进行计数。

SELECT SUM(salary) FROM employees;  -- NULL values are ignored
SELECT AVG(salary) FROM employees;  -- NULL values are ignored
SELECT COUNT(manager_id) FROM employees;  -- NULL values are ignored
SELECT COUNT(*) FROM employees WHERE manager_id IS NULL;  -- Counts only NULL values

处理连接中的 NULL

执行连接时,NULL 值可能会导致意外结果。例如,INNER JOIN 排除连接条件中具有 NULL 值的行,而 LEFT JOIN 包括它们。

SELECT e.name, d.department_name
FROM employees e
LEFT JOIN departments d ON e.department_id = d.id;

由于 LEFT JOIN,此查询检索所有员工,包括那些没有部门的员工。

处理 SQL 查询中的 NULL

使用合并

COALESCE 函数返回表达式列表中的第一个非 NULL 值。它对于用默认值替换 NULL 很有用。

SELECT name, COALESCE(manager_id, 'No Manager') AS manager_id
FROM employees;

此查询将 NULL manager_id 值替换为字符串“No Manager”。

使用 IFNULL 或 ISNULL

许多 SQL 方言提供 IFNULL (MySQL) 或 ISNULL (SQL Server) 等函数来处理 NULL 值。

-- MySQL
SELECT name, IFNULL(manager_id, 'No Manager') AS manager_id FROM employees;

-- SQL Server
SELECT name, ISNULL(manager_id, 'No Manager') AS manager_id FROM employees;

使用 NULLIF

如果两个参数相等,NULLIF 函数返回 NULL;否则,它返回第一个参数。它对于避免被零除错误很有用。

SELECT price / NULLIF(quantity, 0) AS unit_price
FROM products;

此查询通过在数量为零时返回 NULL 来防止被零除。

NULL 处理的最佳实践

  1. 定义默认值:创建表时,定义列的默认值以尽量减少 NULL 的出现。
  2. 使用适当的函数:利用 COALESCE、IFNULL 和 NULLIF 等函数有效地处理 NULL 值。
  3. 验证数据:实施数据验证规则以防止出现不需要的 NULL 值。
  4. 考虑数据库设计:设计数据库架构以适当处理 NULL 值,考虑对查询和性能的影响。

结论

在 SQL 中处理 NULL 值需要仔细考虑和理解它们在不同操作中的行为。通过使用适当的 SQL 函数并遵循最佳实践,您可以确保数据库查询产生准确且可靠的结果。无论您是检查 NULL、执行聚合还是连接表,正确的 NULL 处理对于维护数据完整性和在 SQL 操作中实现所需结果都至关重要。

版本声明 本文转载于:https://dev.to/kellyblaire/null-handling-in-sql-1mp2?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中3个Party Package将另一个PAXPANCE带有导入式套件之间的另一个软件包,并在导入式套件之间导入另一个软件包。如回声消息所证明的那样: go.etcd.io/bbolt [&&&&&&&&&&&&&&&&...
    编程 发布于2025-07-18
  • 在程序退出之前,我需要在C ++中明确删除堆的堆分配吗?
    在程序退出之前,我需要在C ++中明确删除堆的堆分配吗?
    在C中的显式删除 在C中的动态内存分配时,开发人员通常会想知道是否有必要在heap-procal extrable exit exit上进行手动调用“ delete”操作员,但开发人员通常会想知道是否需要手动调用“ delete”操作员。本文深入研究了这个主题。 在C主函数中,使用了动态分配变量(H...
    编程 发布于2025-07-18
  • 使用jQuery如何有效修改":after"伪元素的CSS属性?
    使用jQuery如何有效修改":after"伪元素的CSS属性?
    在jquery中了解伪元素的限制:访问“ selector 尝试修改“:”选择器的CSS属性时,您可能会遇到困难。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    编程 发布于2025-07-18
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-07-18
  • 图片在Chrome中为何仍有边框?`border: none;`无效解决方案
    图片在Chrome中为何仍有边框?`border: none;`无效解决方案
    在chrome 中删除一个频繁的问题时,在与Chrome and IE9中的图像一起工作时,遇到了一个频繁的问题。和“边境:无;”在CSS中。要解决此问题,请考虑以下方法: Chrome具有忽略“ border:none; none;”的已知错误,风格。要解决此问题,请使用以下CSS ID块创建带...
    编程 发布于2025-07-18
  • 在JavaScript中如何并发运行异步操作并正确处理错误?
    在JavaScript中如何并发运行异步操作并正确处理错误?
    同意操作execution 在执行asynchronous操作时,相关的代码段落会遇到一个问题,当执行asynchronous操作:此实现在启动下一个操作之前依次等待每个操作的完成。要启用并发执行,需要进行修改的方法。 第一个解决方案试图通过获得每个操作的承诺来解决此问题,然后单独等待它们: co...
    编程 发布于2025-07-18
  • C++成员函数指针正确传递方法
    C++成员函数指针正确传递方法
    如何将成员函数置于c [&& && && && && && && && && && &&&&&&&&&&&&&&&&&&&&&&&华仪的函数时,在接受成员函数指针的函数时,要在函数上既要提供指针又可以提供指针和指针到函数的函数。需要具有一定签名的功能指针。要通过成员函数,您需要同时提供对象指针(此...
    编程 发布于2025-07-18
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-07-18
  • 切换到MySQLi后CodeIgniter连接MySQL数据库失败原因
    切换到MySQLi后CodeIgniter连接MySQL数据库失败原因
    无法连接到mySQL数据库:故障排除错误消息要调试问题,建议将以下代码添加到文件的末尾.//config/database.php并查看输出: ... ... 回声'... echo '<pre>'; print_r($db['default']); echo '</pr...
    编程 发布于2025-07-18
  • 在UTF8 MySQL表中正确将Latin1字符转换为UTF8的方法
    在UTF8 MySQL表中正确将Latin1字符转换为UTF8的方法
    在UTF8表中将latin1字符转换为utf8 ,您遇到了一个问题,其中含义的字符(例如,“jáuòiñe”)在utf8 table tabled tablesset中被extect(例如,“致电。为了解决此问题,您正在尝试使用“ mb_convert_encoding”和“ iconv”转换受...
    编程 发布于2025-07-18
  • 如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    编程 发布于2025-07-18
  • 为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    网格超过身体,用100%grid-template-columns 为什么在grid-template-colms中具有100%的显示器,当位置设置为设置的位置时,grid-template-colly修复了?问题: 考虑以下CSS和html: class =“ snippet-code”> g...
    编程 发布于2025-07-18
  • 您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    在javascript console 中显示颜色是可以使用chrome的控制台显示彩色文本,例如红色的redors,for for for for错误消息?回答是的,可以使用CSS将颜色添加到Chrome和Firefox中的控制台显示的消息(版本31或更高版本)中。要实现这一目标,请使用以下模...
    编程 发布于2025-07-18
  • 为什么我的CSS背景图像出现?
    为什么我的CSS背景图像出现?
    故障排除:CSS背景图像未出现 ,您的背景图像尽管遵循教程说明,但您的背景图像仍未加载。图像和样式表位于相同的目录中,但背景仍然是空白的白色帆布。而不是不弃用的,您已经使用了CSS样式: bockent {背景:封闭图像文件名:背景图:url(nickcage.jpg); 如果您的html,css...
    编程 发布于2025-07-18
  • Java是否允许多种返回类型:仔细研究通用方法?
    Java是否允许多种返回类型:仔细研究通用方法?
    在Java中的多个返回类型:一种误解类型:在Java编程中揭示,在Java编程中,Peculiar方法签名可能会出现,可能会出现,使开发人员陷入困境,使开发人员陷入困境。 getResult(string s); ,其中foo是自定义类。该方法声明似乎拥有两种返回类型:列表和E。但这确实是如此吗...
    编程 发布于2025-07-18

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3