oracle 中关于null的操作

空值

    空值一般用NULL表示

    一般表示未知的、不确定的值,也不是空格

    一般运算符与其进行运算时,都会为空

    空不与任何值相等

    表示某个列为空用:IS NULL  不能使用COMM=NULL这种形式

    某个列不为空:IS NOT NULL 不能使用COMM != NULL 这种形式

    空值在作升序排列时,空值会放到最后。

    相反作降序排列时,空值会放在最前。

 空值作逻辑运算时:

    AND运算:

    F AND F =F       F AND T =F       F AND NULL =F

    T AND F =F       T AND T =T       T AND NULL IS NULL

    NULL AND F =F    NULL AND T IS NULL   NULL AND NULL IS NULL

    就是说AND的优先级是:F ->NULL ->T

    OR运算:

    T OR T =T     T OR F =T     T OR NULL =T

    F OR T =T     F OR F =F     F OR NULL IS NULL

    NULL OR T =T  NULL OR F IS NULL NULL OR NULL IS NULL

    OR运算优先级:T ->NULL ->F

    NOT运算:

       NOT T =F

       NOT F =T

       NOT NULL IS NULL

 与空值相关的函数:

    NVL 函数

       格式:NVL(表达式1,表达式2)

       作用:测试表达式的值,如果表达式1为空,则返回表达式2的值;不为空,返回表达式1的值。

    NVL2   函数

       格式:NVL2(表达式1,表达式2,表达式3)

       作用:测试表达式的值,表达式1不为空,返回表达式2的值,如果为空,则返回表达式3的值。

    NULLIF  相等为空

       格式:NULLIF (表达式1,表达式2)

       作用:比较表达式1和表达式2的值,如果两个相等则返回为空,否则返回表达式1的值。

    COALESCE    找非空

       格式:COALESCE (表达式1,表达式2,表达式3,...,表达式n)

       作用:返回第一个不为空的值,如果所有的都为空,则返回NULL。

演示:

Create Table Test6(
       id varchar2(30),
       name varchar2(30),
       age number(2),
       sex varchar2(2)
)

建表语句

结果集

1、nvl函数

select id,name,nvl(TO_CHAR(age),'未录入'),nvl(TO_CHAR(sex),'未录入') from Test6

2、nvl2函数

       格式:NVL2(表达式1,表达式2,表达式3)

       作用:测试表达式的值,表达式1不为空,返回表达式2的值,如果表达式1不为空,则返回表达式3的值。

select id,name,NVL2(TO_CHAR(age),2*(age+sex),age) AS othesr from Test6;

运算方式和?:运算规则一致当TO_ChAR(age)不为空(true)时,执行2*(age+sex),否则就执行后面的表达式age

注意:NULL和任何数进行算数操作,其返回值都是NULL。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏菜鸟致敬

MySQL 数据类型

MySQL中定义数据字段的类型对你数据库的优化是非常重要的。 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。 ---- 数值类...

32170
来自专栏PHP在线

MySQL字段类型的详细解释

MySQL支持大量的列类型,它可以被分为3类:数字类型、日期和时间类型以及字符串(字符)类型。 概述有意简化,更详细的说明应该考虑到有关特定列类型的附加信息,例...

39490
来自专栏GreenLeaves

关于null的操作

空值     空值一般用NULL表示     一般表示未知的、不确定的值,也不是空格     一般运算符与其进行运算时,都会为空     空不与任何值相等   ...

22070
来自专栏与神兽党一起成长

[MySQL]查询学生选课的情况(一)

这是我工作遇到的问题,现在自己设计一个简化的类似场景,现实中这样的数据表设计可能有很多不合理的地方。 首先看表结构:

40250
来自专栏calmound

设计模式--单例模式Singleton

单例模式顾名思义整个程序下只有一个实例,例如一个国家只有一个皇帝,一个军队只有一个将军。 单例模式的书写又分为饿汉模式和懒汉模式 饿汉模式    类中代码 pa...

29390
来自专栏java小白

MySQL WHERE子句内使用正则表达式搜索

18850
来自专栏一个会写诗的程序员的博客

MySQL中函数CONCAT 、CONCAT_WS、GROUP_CONCATCONCAT_WSCONCATGROUP_CONCAT

CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。

7510
来自专栏王磊的博客

MongoDB Query 的几个方法

Query.All("name", "a", "b");//通过多个元素来匹配数组 Query.And(Query.EQ("name", "a"), Query...

32880
来自专栏杨建荣的学习笔记

MySQL数据类型(r3笔记第87天)

今天在本地装了一个MySQL的学习环境,简单的熟悉了一下。准备开始好好学习MySQL了。 学习编程语言我都是从数据类型入手。每种编程语言的数据类型都有自己的特点...

301100
来自专栏黑泽君的专栏

Java语言中:运算符优先级表

12010

扫码关注云+社区

领取腾讯云代金券