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;