NVL()函数的用法及注意事项(亲身感悟)

2024-03-04 02:48

本文主要是介绍NVL()函数的用法及注意事项(亲身感悟),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、函数介绍
      • 1.NVL函数是一个空值转换函数。
      • 2.两种用法
      • 3.一种功能
    • 二、注意事项(亲身感悟)

一、函数介绍

1.NVL函数是一个空值转换函数。

该函数的目的是把一个空值(null)转换成一个实际的值。

2.两种用法

用法一
(1)格式:NVL(表达式1,表达式2)
(2)功能:如果表达式1为空值,NVL返回值为表达式2的值,否则返回表达式1的值。
(3) 注意:其表达式的值可以是数字型、字符型和日期型。但是表达式1和表达式2的数据类型必须为同一个类型。

对数字型: NVL(comm,0);对字符型 NVL( TO_CHAR(comm), 'No Commission')对日期型 NVL(hiredate,' 31-DEC-99')
其中comm为你需要判断是否为空的列名

用法二
(1)格式:NVL2(表达式1,表达式2,表达式3)
(2)功能:如果表达式1为空,返回值为表达式3的值。如果表达式1不为空,返回值为表达式2的值。
(3)样例:

 NVL2(comm,'sal+comm',sal)
如果comm为空,就返回sal 的值。如果 comm 不为空(null),就返回表达式 sal+comm的值。 

3.一种功能

自己总结了一下NVL()函数的功能,方便记忆:第一个表达式的值如果为空,就返回最后一个表达式的值。

二、注意事项(亲身感悟)

做毕设时判断用户的性别,是否为空(null),如果为空将其替换为unknow。尝试多次,显示的结果都是不为空。但我的性别字段里明明有null值。如图显示。
在这里插入图片描述

  • 我的查询语句:
 val result1 = sqlContext.sql("select userid,usertype,bikeid," +"NVL(gender,'unknow') as gender,birthyear " +"from user_condition ").show()

查询结果仍和上图一样。

  • 后来我用用isnan()函数,和if语句判断性别字段是否为空,如果为空返回y。结果还是和nvl()函数效果那样,显示不为空。
  • 查询语句
sqlContext.sql("select userid,usertype,bikeid,if(isnan(gender),'y','n')as genderIsNull,birthyear " +"from user_condition limit 10 ").show()

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

  • 最后经过多次上网查寻,以为空值是NULL或者是空格。反复修改代码,进行测试,查看显示结果。第二天大脑终于开窍。只有待替换的整列值都为空(null), 才能替换成自己想要的结果值。而我的性别字段有的值为null、有的值为Male、有的值为Female,所以用NVL()函数,没有效果。

这篇关于NVL()函数的用法及注意事项(亲身感悟)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/771776

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

Java中HashMap的用法详细介绍

《Java中HashMap的用法详细介绍》JavaHashMap是一种高效的数据结构,用于存储键值对,它是基于哈希表实现的,提供快速的插入、删除和查找操作,:本文主要介绍Java中HashMap... 目录一.HashMap1.基本概念2.底层数据结构:3.HashCode和equals方法为什么重写Has

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N