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 NULL
或 IS NOT NULL
delete from student where gender is null;
2、NULL值的运算操作
NULL
与任何数字运算结果还是为NULL
,NULL
与字符串连接等于什么都没做。
--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;
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 为DeepSeek添加本地知识库
· 精选4款基于.NET开源、功能强大的通讯调试工具
· DeepSeek智能编程
· 大模型工具KTransformer的安装
· [计算机/硬件/GPU] 显卡