nvl,空时的推断和取值

时间:2022-07-02 17:23:04

nvl  

NVL的概念

  Oracle/PLSQL中的一个函数。   格式为:   NVL( string1, replace_with)   功能:假设string1为NULL,则NVL函数返回replace_with的值,否则返回string1的值,假设两个參数的都为NULL ,则返回NULL。   注意事项:string1和replace_with必须为同一数据类型,除非显示的使用TO_CHAR函数。   例:NVL(TO_CHAR(numeric_column), 'some string') 当中numeric_column代指某个数字类型的值。   例:nvl(yanlei777,0) > 0   NVL(yanlei777, 0) 的意思是 假设 yanlei777 是NULL, 则取 0值   通过查询获得某个字段的合计值,假设这个值为null将给出一个预设的默认值   比如:   select nvl(sum(t.dwxhl),1)   from tb_jhde t   就表示假设sum(t.dwxhl) = NULL 就返回 1   还有一个有关的实用方法   declare i integer   select nvl(sum(t.dwxhl),1) into i from tb_jhde t where zydm=-1这样就能够把获得的合计值存储到变量   i中,假设查询的值为null就把它的值设置为默认的1   orcale中:   select nvl(rulescore,0) from zwjc_graderule where rulecode='FWTD';   假设记录中不存在rulecode ='FWTD'的数据.则查不出数据.   select nvl(rulescore,0) into rule_score from zwjc_graderule where rulecode='FWTD';会报查不到数据的错   select nvl(sum(rulescore),0) from zwjc_graderule where rulecode='FWTD';   假设记录中不存在rulecode ='FWTD'的数据.还是能够得到一行列名为nvl(rulescore,0),值为0的数据.   select nvl(sum(rulescore),0) into rule_score from zwjc_graderule where rulecode='FWTD'; 不会报错

NVL的扩展-NVL2

  Oracle在NVL函数的功能上扩展,提供了NVL2函数。   NVL2(E1, E2, E3)的功能为:假设E1为NULL,则函数返回E3,否则返回E2。

ORACLE CASE WHEN 及 SELECT CASE WHEN的使用方法
SELECT col1, col2,

  CASE

  WHEN col3 > 1 AND col3 <2

  THEN '1'

  WHEN col3 > 2 AND col3 <3

  THEN '2'

  WHEN col3 > 3 AND col3 <4

  THEN '3'

  ELSE '4'

  END mylevel

  FROM table1

  注意点:

  1、以CASE开头,以END结尾

  2、分支中WHEN 后跟条件,THEN为显示结果

  3、ELSE 为除此之外的默认情况,相似于高级语言程序中switch case的default,能够不加

  4、END 后跟别名