oracle decode函数的怪事。 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 (空值)可是什么也没返回啊。 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 select decode(nvl(a,' '),' ','Y','N') as aa ,length(a) as bb from table1 where b = '123' select a from table1 where b = '123' 本来就不会返回结果,你那函数转换后肯定还是不会返回结果了 没有返回结果,是什么概念呢,那 a 是什么呢。我想在SQL实现这个功能功能,如果要取得栏位没有返回,或者返回为null,则返回 'N',否则返回 'Y',在 SQL 里面能做到吗,还是说办不到,只能在程序里面判断了。 select decode(b,'123','Y','N') as aa ,length(a) as bb from table1 用decode(count(*),0,'N','Y')判断 如果没有123这条记录, 谈何返回空值还是null叻,一条记录都不会有。 用这个试试:select nvl(a,'') as a from table1 where b = '123' ORACLE中NULL不是空而是未确定,对NULL坐的任何操作都返回空。 我想在SQL实现这个功能功能,如果要取得栏位没有返回,或者返回为null,则返回 'N',否则返回 'Y',在 SQL 里面能做到吗,还是说办不到,只能在程序里面判断了。 可用nvl2函数解决:select NVL2 (a, 'Y', 'N') from table1 where b = '123' NVL2 (expr1, expr2, expr3)expr1不为NULL,返回expr2;为NULL,则返回expr3 select decode(count(*),0,'N','Y') from dual where 1=2前面就说了要你用这个的,试试符合你的要求不 一个基础的小问题,求解 ORacle表联查 求Oracle9i SQL替换语句 登录SQL PLUS Oracle客户端连接问题! 基础问题,Oracle XE 的 SID 和 TNS 是什么 @@ROWCOUNT,存储过程返回受影响的行数。分不够可在加。 哪里能下载到ORACLE9.2.0.4 for linux的patch文件?急啊!!! 请教select查询语句的这个错误? 利用存储过程自动更新数据库 在RHEL5.3上安装Oracle10g的10201版本,需要哪些程序包 求助:原有数据库连接可正常使用,无法建立新的连接
select decode(nvl(a,' '),' ','Y','N') as aa ,length(a) as bb from table1 where b = '123'
本来就不会返回结果,你那函数转换后肯定还是不会返回结果了
没有返回结果,是什么概念呢,那 a 是什么呢。我想在SQL实现这个功能功能,如果要取得栏位没有返回,或者返回为null,则返回 'N',否则返回 'Y',在 SQL 里面能做到吗,还是说办不到,只能在程序里面判断了。
如果没有123这条记录, 谈何返回空值还是null叻,一条记录都不会有。
select NVL2 (a, 'Y', 'N') from table1 where b = '123' NVL2 (expr1, expr2, expr3)
expr1不为NULL,返回expr2;为NULL,则返回expr3
前面就说了要你用这个的,试试符合你的要求不