zoukankan      html  css  js  c++  java
  • nvl,空时的推断和取值

    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 后跟别名

  • 相关阅读:
    MySQL之自增长
    MySQL字符集和校对规则
    关于MySQL安装目录bin下工具的详解
    Linux下载安装配置FTP
    Linux和Windows平台安装MySQL的两种方式
    kali安装linux-header
    Mysql之事务
    Linux之ps命令
    Linux之dd命令
    python爬虫之xpath的基本使用
  • 原文地址:https://www.cnblogs.com/yxwkf/p/3922132.html
Copyright © 2011-2022 走看看