使用decode函数select decode(col2,0,0,col1/col2) 
  from table;select * 
  from table
 where docode(col2,0,0,col1/col2)>1;---------------------------------------
decode函数:
  decode(col2,0,0,col1/col2)
         col2 --用来判断的条件
         0 --当条件达到第一个值时
         0 --当条件达到第一个值时返回的值
         col1/col2 --当没有满足条件值时,默认返回的值
         说明:在0,0,之后可以继续添加条件值,和符合条件后的返回值

解决方案 »

  1.   

    含义解释: 
    DECODE(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)该函数的含义如下:
    IF 条件=值1 THEN
        RETURN(翻译值1)
    ELSIF 条件=值2 THEN
        RETURN(翻译值2)
        ......
    ELSIF 条件=值n THEN
        RETURN(翻译值n)ELSE
        RETURN(缺省值)
    END IF使用方法: 
    1、比较大小
    select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值
    sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1例如:
    变量1=10,变量2=20
    则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。
    2、表、视图结构转化
    现有一个商品销售表sale,表结构为:
    month    char(6)      --月份
    sell    number(10,2)   --月销售金额现有数据为:
    200001  1000
    200002  1100
    200003  1200
    200004  1300
    200005  1400
    200006  1500
    200007  1600
    200101  1100
    200202  1200
    200301  1300想要转化为以下结构的数据:
    year   char(4)      --年份
    month1  number(10,2)   --1月销售金额
    month2  number(10,2)   --2月销售金额
    month3  number(10,2)   --3月销售金额
    month4  number(10,2)   --4月销售金额
    month5  number(10,2)   --5月销售金额
    month6  number(10,2)   --6月销售金额
    month7  number(10,2)   --7月销售金额
    month8  number(10,2)   --8月销售金额
    month9  number(10,2)   --9月销售金额
    month10  number(10,2)   --10月销售金额
    month11  number(10,2)   --11月销售金额
    month12  number(10,2)   --12月销售金额结构转化的SQL语句为:
    create or replace view v_sale(year,month1,month2,month3,
    month4,month5,month6,month7,month8,month9,month10,month11,month12)
    as
        select
        substrb(month,1,4),
        sum(decode(substrb(month,5,2),'01',sell,0)),
        sum(decode(substrb(month,5,2),'02',sell,0)),
        sum(decode(substrb(month,5,2),'03',sell,0)),
        sum(decode(substrb(month,5,2),'04',sell,0)),
        sum(decode(substrb(month,5,2),'05',sell,0)),
        sum(decode(substrb(month,5,2),'06',sell,0)),
        sum(decode(substrb(month,5,2),'07',sell,0)),
        sum(decode(substrb(month,5,2),'08',sell,0)),
        sum(decode(substrb(month,5,2),'09',sell,0)),
        sum(decode(substrb(month,5,2),'10',sell,0)),
        sum(decode(substrb(month,5,2),'11',sell,0)),
        sum(decode(substrb(month,5,2),'12',sell,0))
        from sale
        group by substrb(month,1,4);
      

  2.   

    比如说a=0; b=3select b/decode(a,0,1,a) from dual; b除以a,如果啊为0则结果为b/1,如果不为0,则结果为b/a
      

  3.   

    楼上已经说明了如何处理除0,ZERO_DIVIDE 这是个异常,应该出现在异常里:
    例如:
    declare
     var1 char;
    begin
    select 3/0 into var1 from dual;
    exception
     when ZERO_DIVIDE then
         dbms_output.put_line('除数为0');
    end;
      

  4.   

    如果写在函数中create function test(p_in in number) return number as
        v_1 number:=9;
        v_2 number:=p_in;
        v_r number ;
    begin
        v_r:=v_1/v_2;    --不知道v_2是否为0
        return v_r;
        exception        
            when ZERO_DIVIDE then  --如果出现除0错误,返回0 
                return 0; 
            when others then       --如果出现其他错误,返回-99 
                return -99;
    end;
      

  5.   

    谢谢各位高手的指点,但我要的是“a/b(0)”不知道用decode(条件怎么用)谢谢!!
      

  6.   

    不好意思又出了点问题:我现希要的是 a/b 如果b=0 then a/b =0
    这要如何使用decode()。谢谢!!!
    trunc((sum(nvl(f_this_report_Count,0))-sum(nvl(f_last_report_Count,0)))/sum(nvl(f_last_report_Count,0)),3)*100
      

  7.   

    a:=5   b变量select decode(b,0,0,a)/decode(b,0,1,b) from dual--如果b是0,则分子为0,分母为1,
    --如果B不是0则分子为a,分母为b