table1 该表有a,b两个字段。假设没有 b = '123' 的记录,则 select a from table1 where b = '123' 结果是 null还是空值啊select decode(a,null,'Y','N') as aa ,length(a) as bb from table1 where b = '123' 应该返回 aa          bb Y           (空值)可是什么也没返回啊。

解决方案 »

  1.   


    select decode(nvl(a,' '),' ','Y','N') as aa ,length(a) as bb from table1 where b = '123'
      

  2.   

    select a from table1 where b = '123' 
    本来就不会返回结果,你那函数转换后肯定还是不会返回结果了
      

  3.   


    没有返回结果,是什么概念呢,那 a 是什么呢。我想在SQL实现这个功能功能,如果要取得栏位没有返回,或者返回为null,则返回 'N',否则返回 'Y',在 SQL 里面能做到吗,还是说办不到,只能在程序里面判断了。
      

  4.   

    select decode(b,'123','Y','N') as aa ,length(a) as bb from table1
      

  5.   

    用decode(count(*),0,'N','Y')判断
      

  6.   


    如果没有123这条记录, 谈何返回空值还是null叻,一条记录都不会有。
      

  7.   

    用这个试试:select nvl(a,'') as a from table1 where b = '123' 
      

  8.   

    ORACLE中NULL不是空而是未确定,对NULL坐的任何操作都返回空。
      

  9.   

    我想在SQL实现这个功能功能,如果要取得栏位没有返回,或者返回为null,则返回 'N',否则返回 'Y',在 SQL 里面能做到吗,还是说办不到,只能在程序里面判断了。
      

  10.   

    可用nvl2函数解决:
    select NVL2 (a, 'Y', 'N') from table1 where b = '123' NVL2 (expr1, expr2, expr3)
    expr1不为NULL,返回expr2;为NULL,则返回expr3
      

  11.   

    select decode(count(*),0,'N','Y') from dual where 1=2
    前面就说了要你用这个的,试试符合你的要求不