有关oracle的order by语句中使用decode的问题

WinLogo811 2008-12-27 03:14:01
表名:a
字段:sid

select * from a ordey by decode(sid, '0010', 1, 0)

上面的order by decode(decode(sid, '0010', 1, 0)
是什么意思?

我的设计书里面的文字要求是这样的:

order by decode(sid, '0010', 1, 0) (降顺)

我看不懂,写语句的时候,我照着写,但没有加后面的"(降顺)"

是不是应该写成如下:

order by decode(sid, '0010', 1, 0) DESC


...全文
1153 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiaohu0901 2008-12-27
  • 打赏
  • 举报
回复
4楼的正解
bw555 2008-12-27
  • 打赏
  • 举报
回复
decode(sid, '0010', 1, 0)
就是想把sid='0010'的放在最后面

order by decode(sid, '0010', 1, 0) DESC
就是想把sid='0010'的放在最前面
ks_reny 2008-12-27
  • 打赏
  • 举报
回复
order by decode(sid, '0010', 1, 0)

order by sid (ASC,DESC)有什么区别呢?
xuyuhai 2008-12-27
  • 打赏
  • 举报
回复
DECODE函数
  DECODE是Oracle公司独家提供的功能,它是一个功能很强的函数。它虽然不是SQL的标准,但对于性能非常有用。到目前,其他的数据库供应商还不能提供类似DECODE的功能,甚至有的数据库的供应商批评Oracle的SQL不标准。实际上,这种批评有些片面或不够水平。就象有些马车制造商抱怨亨利。福特的“马车”不标准一样。
  1 DECODE 中的if-then-else逻辑
  在逻辑编程中,经常用到If – Then –Else 进行逻辑判断。在DECODE的语法中,实际上就是这样的逻辑处理过程。它的语法如下:
  DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )
  Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,Decode 结果就返回else 。
  需要注意的是,这里的if、then及else 都可以是函数或计算表达式。
  2 DECODE 的简单例子
  Oracle系统中就有许多数据字典是使用decode 思想设计的,比如记录会话信息的V$SESSION数据字典视图就是这样。我们从《Oracle8i/9i Reference》资料中了解到,当用户登录成功后在V$SESSION中就有该用户的相应记录,但用户所进行的命令操作在该视图中只记录命令的代码(0—没有任何操作,2—Insert…),而不是具体的命令关键字。因此,我们需要了解当前各个用户的名字及他们所进行的操作时,要用下面命令才能得到详细的结果:
  select sid,serial#,username,
  DECODE(command,
  0,’None’,
  2,’Insert’,
  3,’Select’,
  6,’Update’,
  7,’Delete’,
  8,’Drop’,
  ‘Other’) cmmand
  from v$session where username is not null;
  3 DECODE实现表的转置
  数据库中的表是由列和行构成的一个二维表。一般列在任何数据库中都是有限的数量,而行的变化较大,如果表很大,行的数量可能大上千万行。同一列的不同行可能有不同的值,而且不是预先定义的。
范佩西_11 2008-12-27
  • 打赏
  • 举报
回复
order by默认是升序降序的话加个desc
codearts 2008-12-27
  • 打赏
  • 举报
回复
order by decode(sid, '0010', 1, 0)

就是把sid = 0010的排到前面,其它的排到后面
butchroller 2008-12-27
  • 打赏
  • 举报
回复
对的。
decode(sid, '0010', 1, 0) 等价于:case sid when '0010' then 1 else 0 end

17,086

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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