SQL中对数据字段null值的处理

简介: SQL中对数据字段null值的处理
在我们平常的数据开发工作中,由于数据质量的问题或者是在数据关联的过程中,可能会出现字段内容为null值的情况,如果该字段需要展示或者是参与计算的话,怎么处理这些内容就很重要了,以下是我用到的SQL中对null值的处理,与大家分享。

一、hive数据库

hive里面对null值的处理用到的函数是COALESCE()和nvl()

1,COALESCE()

(1)函数格式与释义

COALESCE()函数
语法格式:COALESCE(expression_1,expression_2,expression_3......expression_n)
释义:依次参考各参数表达式,遇到非null值即停止并返回该值。如果所有的表达式都是空值,最终将返回一个空值。

(2)COALESCE()实战演练
将null值置为0

SELECT * FROM test.test_data ;

在这里插入图片描述

SELECT id,name,sex,COALESCE(sex,'0') 
FROM test.test_data;

在这里插入图片描述
查询几个字段里面第一个非空的内容

SELECT *,COALESCE(sex,name,age)
FROM test.test_data

在这里插入图片描述

释义:
id为1,2,3的数据,sex不为空,所以查询出来是sex字段的值,id为4的数据,sex为空,name字段不为空,所以查询出来的是name字段的内容。

2,nvl()函数

(1)函数格式与释义

格式:nvl(expression_1,expression_2)
释义:如果表达式1的值为空,返回表达式2的值;如果表达式1的值不为空,返回表达式1的值。
注意:表达式的值可以是数字型、字符型和日期型。但是表达式1和表达式2的数据类型必须为同一个类型。

(2)nvl()函数实战练习

查询语句:

SELECT *,nvl(sex,name) 
FROM test.test_data 

输出结果:
在这里插入图片描述

释义:
nvl()函数是如果表达式1为空,则返回表达式2的值,如果表达式1不为空,则返回表达式1的值
这里sex字段为表达式1,name字段为表达式2,结果则如图所示。

二、MySQL数据库

1,函数格式与释义

IFNULL() 函数
语法格式:IFNULL(表达式1,表达式2);
释义:如果 表达式1 不为NULL,则IFNULL函数返回 表达式1 ; 否则返回 表达式2 的结果。
注意:这里的表达式 两个参数可以是文字值或者表达式

2,实战演练

(1)当第一个表达式不为空,返回第一个表达式内容

SELECT ifnull('xiaoming','xiaohua');

在这里插入图片描述

(2)当第一个表达式为空,返回第二个表达式内容

SELECT IFNULL(NULL,'xiaohua') ;

在这里插入图片描述

(3)字段内容null值置为0

SELECT IFNULL(NULL,0) ;

在这里插入图片描述
如果想要判断整个字段的话,就将第一个表达式的位置换为需要置为0的字段就可以了。

相关文章
|
7月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
简介:本文整理自阿里云高级技术专家李麟在Flink Forward Asia 2025新加坡站的分享,介绍了Flink 2.1 SQL在实时数据处理与AI融合方面的关键进展,包括AI函数集成、Join优化及未来发展方向,助力构建高效实时AI管道。
1058 43
|
7月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
本文整理自阿里云的高级技术专家、Apache Flink PMC 成员李麟老师在 Flink Forward Asia 2025 新加坡[1]站 —— 实时 AI 专场中的分享。将带来关于 Flink 2.1 版本中 SQL 在实时数据处理和 AI 方面进展的话题。
466 0
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
|
8月前
|
SQL
SQL如何只让特定列中只显示一行数据
SQL如何只让特定列中只显示一行数据
|
8月前
|
SQL Java 数据库连接
updateByPrimaryKeySelective()方法因字段为null导致的更新不成功问题解决办法
为了让这个解决方案更容易融入到现有系统中,其实现应该尽量简单且无缝,避免重复代码,并提高代码复用性。结合上述方法中提供的策略,应可以解决在使用 `updateByPrimaryKeySelective()`方法时因字段为null导致的更新不成功问题。请根据实际业务需求和上下文选择最合适的方案。这样的解决方案能够达到更佳的代码质量和维护性。
614 14
|
8月前
|
SQL
SQL中如何删除指定查询出来的数据
SQL中如何删除指定查询出来的数据
|
8月前
|
SQL 关系型数据库 MySQL
SQL如何对不同表的数据进行更新
本文介绍了如何将表A的Col1数据更新到表B的Col1中,分别提供了Microsoft SQL和MySQL的实现方法,并探讨了多表合并后更新的优化方式,如使用MERGE语句提升效率。适用于数据库数据同步与批量更新场景。
|
9月前
|
SQL DataWorks 数据管理
SQL血缘分析实战!数据人必会的3大救命场景
1. 开源工具:Apache Atlas(元数据管理)、Spline(血缘追踪) 2. 企业级方案:阿里DataWorks血缘分析、腾讯云CDW血缘引擎 3. 自研技巧:在ETL脚本中植入版本水印,用注释记录业务逻辑变更 📌 重点总结:
|
SQL JSON 数据库
influxdb 端点使用http进行sql查询,写数据
influxdb 端点使用http进行sql查询,写数据
1105 0
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录

热门文章

最新文章