ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Oracle学习笔记:nvl、nvl2、nullif、decode函数

2020-03-11 22:58:22  阅读:357  来源: 互联网

标签:nvl null decode expression1 Oracle 返回值 expression2 select


一、nvl函数

功能:从两个表达式返回一个非 NULL 值。

语法:

select nvl(expression1, expression2)
-- 如果 expression1 计算结果为 null,则返回 expression2
-- 任意一种数据类型
-- 如果 expression1、expression2 都为null则返回null

select nvl(null, 1) from dual;
-- 1

返回值类型:字符型、日期型、日期时间型、数值型、货币型、逻辑型或 null 值。

两个表达式数据类型必须一致。

二、nvl2函数

语法:

select nvl2(expression1, expression2, expression3)
-- expression1 不为null则返回 expression2
-- expression1 为null则返回 expression3

expression2 和 expression3 类型不同情况下,会强制转换为 expression2 数据类型。

select nvl2(expr, 1, 0) from dual;

三、nullif函数

语法:

select nullif(100, 200)
-- 100

说明:相等返回null,不等返回 expression1。

四、decode函数

SQL中没有逻辑判断语句(分支语句),decode 函数可以完成类似功能。

语法:

select decode(条件, 值1, 返回值1, 值2, 返回值2..., 值n, 返回值n, 缺省值);
/*
IF 条件 = 值1 THEN
    RETURN(返回值1)
ELSIF 条件 = 值2 THEN
    RETURN(返回值2)
    ......
ELSIF 条件 = 值n THEN
    RETURN(返回值n)
ELSE
    RETURN(缺省值)
END IF
*/

应用:结合 lpad 补全函数,可以使主键的值自动加1并补0。

select lpad(decode(count(id), 0, 1, max(to_number(id)+1)), 14, '0') as col from dual;

应用:性别统计。

select decode(sex, '男', 1, 0), decode(sex, '女', 1, 0) from table_name;

应用:order by 对字符进行特定的排序。

select * from table_name
order by decode(subject_name, '语文', 1, '数学', 2, '英语', 3);

标签:nvl,null,decode,expression1,Oracle,返回值,expression2,select
来源: https://www.cnblogs.com/hider/p/12466170.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有