ICode9

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

Oracle基础(七):NULL的操作和空值函数

2022-06-08 06:31:06  阅读:182  来源: 互联网

标签:null sal -- 空值 绩效 comm Oracle NULL


一、NULL值的操作

1、准备一个数据表

CREATE TABLE student(
        id NUMBER(4),
        name CHAR(20),
        gender CHAR(1)
);
INSERT INTO student VALUES(1000,'李莫愁','F');
INSERT INTO student VALUES(1001,'林平之',NULL);--显式插入NULL值
INSERT INTO student (id,name) VALUES(1002,'张无忌');--隐式插入NULL值
commit;
select * from student;

(1)把字段更新为NULL(如果该字段有非空约束,则无法更新为null值,否则会报错)

update student set gender=null where id=1000;

(2)判断字段值是否为NULL,要使用 IS NULLIS NOT NULL

delete from student where gender is null;

2、NULL值的运算操作

NULL与任何数字运算结果还是为NULLNULL与字符串连接等于什么都没做。

--null值连接字符串
select ename||null from emp;--返会字段原来的值

--null值与数字运算
select sal+null from emp;--返回null

--查看每个员工的收入,工资+绩效
select ename,sal,comm,sal+comm from emp;--sal+comm返回null

二、空值函数

1、NVL(arg1,arg2)

当arg1为NULL时,函数返回arg2的值,若不为NULL时,返回arg1本身(参数类型必须一致),

所以该函数的作用是将NULL值替换为非NULL值。

--查看每个员工的收入(工资+绩效)
select ename,sal,comm,sal+nvl(comm,0) from emp;

2、NVL2(arg1,arg2,arg3)

该函数是根据一个值是否为NULL来返回两个不同的结果。

arg1作为判断的条件,当arg1不为NULL时,函数返回arg2,若arg1为NULL,函数则返回arg3

--查看每个员工是否有绩效,即:有绩效显示"有绩效",为NULL的则显示"无绩效"
SELECT ename,comm,NVL2(comm,'有绩效','没有绩效') FROM emp;

--查看每个员工的收入(工资+绩效),不为NULL时返回工资+绩效,为NULL则返回arg3
select ename,sal,comm,sal+NVL2(comm,comm,0) from emp;
select ename,sal,comm,NVL2(comm,sal+comm,sal) from emp;

 

标签:null,sal,--,空值,绩效,comm,Oracle,NULL
来源: https://www.cnblogs.com/codercat/p/16354122.html

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

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

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

ICode9版权所有