表名:a
字段:sidselect * 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

解决方案 »

  1.   

    对的。
    decode(sid, '0010', 1, 0)  等价于:case sid when '0010' then 1 else 0 end
      

  2.   

    order by默认是升序降序的话加个desc
      

  3.   

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

    order by sid  (ASC,DESC)有什么区别呢?
      

  4.   

    decode(sid, '0010', 1, 0) 
    就是想把sid='0010'的放在最后面order by decode(sid, '0010', 1, 0) DESC
    就是想把sid='0010'的放在最前面
      

  5.   

    order by decode(sid, '0010', 1, 0) 就是把sid = 0010的排到前面,其它的排到后面
      

  6.   

    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实现表的转置
      数据库中的表是由列和行构成的一个二维表。一般列在任何数据库中都是有限的数量,而行的变化较大,如果表很大,行的数量可能大上千万行。同一列的不同行可能有不同的值,而且不是预先定义的。