MySQL中创 NVL 函数的使用

作者: cheng 发布时间: 2023-01-08 浏览: 2064 次 编辑

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;