zoukankan      html  css  js  c++  java
  • Oralce 如何将查询结果中的0转成空的

    我们遇到过大多的情况的需求是查询结果中空转为0,这个可以通过oracle的NVL()函数就可以搞定。

    之前做报表客户有个需求,查询出结果为0 要转成空的,不显示0

    那么在oracle有没有现成函数能搞定呢?有的

    1、方法1:NULLIF()函数

    1)介绍

    NULLIF (expr1, expr2),若expr1和expr2相等,返回NULL;不相等,等返回expr1

    2)例子

    --将 0 转成 空 ,结果 空  ---
    select NULLIF('', to_char(0)) SexStr1  from dual;

    结果

    3)实际应用

    -- 将入库通知单的入库数量 将 0 转成 空   ---
    select NULLIF('', to_char(Num))  InNum from Dxc_In_Notice;

    2、方法2:用case when 判断

    1)介绍

        用法就不解释了,跟C#的if else查不多。

    2)例子

    --将 0 转成 空 ,结果 空  ---
    select (case to_char(0) when '1' then '' when '2' then ''else '' end) SexStr2 from dual;

    3)实际应用

    --将 0 转成 空 ,结果 空  ---
    select (case to_char(Sex) when '1' then '' when '2' then ''else '' end) SexStr2 from EdsEmployee;

    注意:NULLIF()  函数的参数类型要一致,case 对象和when对象也一样。

  • 相关阅读:
    Android安全机制
    service不死之身
    图片加载机制比较
    handler机制面试
    SharedPreferences封装类
    文字太长自动缩小
    ANR
    onCreate源码分析
    线程池的启动策略
    Oauth认证协议
  • 原文地址:https://www.cnblogs.com/xielong/p/11214787.html
Copyright © 2011-2022 走看看