oracle decode函数的怪事。

youjianbo_han_87 2009-09-14 11:34:48


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 (空值)

可是什么也没返回啊。
...全文
144 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
youjianbo_han_87 2009-09-14
  • 打赏
  • 举报
回复
没有用,还是什么都没返回
小灰狼W 2009-09-14
  • 打赏
  • 举报
回复
select decode(b,'123','Y','N') as aa ,length(a) as bb from table1
小灰狼W 2009-09-14
  • 打赏
  • 举报
回复
将where 子句去掉
youjianbo_han_87 2009-09-14
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 bluecocoqd 的回复:]
select a from table1 where b = '123'
本来就不会返回结果,你那函数转换后肯定还是不会返回结果了
[/Quote]

没有返回结果,是什么概念呢,那 a 是什么呢。

我想在SQL实现这个功能功能,如果要取得栏位没有返回,或者返回为null,则返回 'N',否则返回 'Y',

在 SQL 里面能做到吗,还是说办不到,只能在程序里面判断了。
bluecocoqd 2009-09-14
  • 打赏
  • 举报
回复
select a from table1 where b = '123'
本来就不会返回结果,你那函数转换后肯定还是不会返回结果了
youjianbo_han_87 2009-09-14
  • 打赏
  • 举报
回复
没有用啊,还是什么没返回。
cosio 2009-09-14
  • 打赏
  • 举报
回复
[Quote=引用楼主 youjianbo_han_87 的回复:]
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          (空值)

可是什么也没返回啊。

[/Quote]

select decode(nvl(a,' '),' ','Y','N') as aa ,length(a) as bb from table1 where b = '123'
youjianbo_han_87 2009-09-14
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 bluecocoqd 的回复:]
select decode(count(*),0,'N','Y') from dual where 1=2
前面就说了要你用这个的,试试符合你的要求不
[/Quote]

可以,没想到,也没看到,嘿嘿,谢谢 各位,结贴散分,
bluecocoqd 2009-09-14
  • 打赏
  • 举报
回复
select decode(count(*),0,'N','Y') from dual where 1=2
前面就说了要你用这个的,试试符合你的要求不
youjianbo_han_87 2009-09-14
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 dream_wu 的回复:]
可用nvl2函数解决:
select NVL2 (a, 'Y', 'N') from table1 where b = '123'

NVL2 (expr1, expr2, expr3)
expr1不为NULL,返回expr2;为NULL,则返回expr3
[/Quote]

不是这个意思,是根本就没有返回。
dream_wu 2009-09-14
  • 打赏
  • 举报
回复
可用nvl2函数解决:
select NVL2 (a, 'Y', 'N') from table1 where b = '123'

NVL2 (expr1, expr2, expr3)
expr1不为NULL,返回expr2;为NULL,则返回expr3
youjianbo_han_87 2009-09-14
  • 打赏
  • 举报
回复
我想在SQL实现这个功能功能,如果要取得栏位没有返回,或者返回为null,则返回 'N',否则返回 'Y',

在 SQL 里面能做到吗,还是说办不到,只能在程序里面判断了。
小灰狼W 2009-09-14
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 wildwave 的回复:]
select decode(b,'123','Y','N') as aa ,length(a) as bb from table1
[/Quote]
这样的话都什么也没返回
只能说你的表式空表吧..
zhangchu_63 2009-09-14
  • 打赏
  • 举报
回复
ORACLE中NULL不是空而是未确定,对NULL坐的任何操作都返回空。
dream_wu 2009-09-14
  • 打赏
  • 举报
回复
用这个试试:select nvl(a,'') as a from table1 where b = '123'
inthirties 2009-09-14
  • 打赏
  • 举报
回复
[Quote=引用楼主 youjianbo_han_87 的回复:]
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          (空值)

可是什么也没返回啊。

[/Quote]

如果没有123这条记录, 谈何返回空值还是null叻,一条记录都不会有。
bluecocoqd 2009-09-14
  • 打赏
  • 举报
回复
用decode(count(*),0,'N','Y')判断

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧