MySQL中创 NVL 函数

发布于:2023-09-15 ⋅ 阅读:(109) ⋅ 点赞:(0)

NVL的定义

NVL(s1, s2):当s1为null时,返回s2,否则返回s1

SELECT NVL('S', 'R') FROM DUAL;   -- S
SELECT NVL(NULL, 'R') FROM DUAL;  -- R

NVL方法的兼容策略

第一种:用 case when 代替 NVL,这种方法代码改造量较大,但胜在一劳永逸,且兼容大部分数据库。

NVL(str1, str2)
CASE WHEN str1 IS NULL THEN str2 ELSE str1 END

第二种:在MySQL数据库创建NVL函数,这种方法无需改动代码,能快速实现兼容。

  • 第一种
create function nvl(str1 varchar(4000), str2 varchar(4000)) 
returns varchar(4000) deterministic
return coalesce(str1, str2);
  • 第二种
create function nvl(str1 varchar(4000), str2 varchar(4000)) 
returns varchar(4000) deterministic
return ifnull(str1, str2);
  • 第三种
create function nvl(str1 varchar(4000), str2 varchar(4000)) 
returns varchar(4000) deterministic
return CASE WHEN str1 IS NULL THEN str2 ELSE str1 END;

b
在这里插入图片描述
在这里插入图片描述

本文含有隐藏内容,请 开通VIP 后查看

网站公告


今日签到

点亮在社区的每一天
去签到