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

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Idea调用WebService的关键步骤和注意事项

《Idea调用WebService的关键步骤和注意事项》:本文主要介绍如何在Idea中调用WebService,包括理解WebService的基本概念、获取WSDL文件、阅读和理解WSDL文件、选... 目录前言一、理解WebService的基本概念二、获取WSDL文件三、阅读和理解WSDL文件四、选择对接