在SQL语句ORDER BY子句中用CASE表达式

 
   | |

导读:本文主要回答在SQL ORDER BY子句中用CASE表达式或通过多个列进行排序的问题。专家建议根本不用CASE表达式。

关键词:Oracle Oracle SQL ORDER BY子句 CASE表达式

正在加载数据... 【TechTarget中国原创】我想在SQL语句ORDER BY子句中用CASE表达式,但是我又想通过多个列进行排序。但是在编辑时我却不断收到“找不到关键字”的错误信息。

【TechTarget中国原创】:我想在SQL语句ORDER BY子句中用CASE表达式,但是我又想通过多个列进行排序。但是在编辑时我却不断收到“找不到关键字”的错误信息。顺便提一下,我可以用到“sortorder”。


 ORDER BY
    CASE WHEN sortorder = 1 THEN x
    WHEN sortorder = 2 THEN x,y
    END;

  答:在以上两种情况下首先要注意的就是,对于sortorder 1和sortorder 2,一些行必须归到"x" 列中的主序列中。所以我们可以按照下面的方法简化ORDER BY子句:


ORDER BY
    CASE WHEN sortorder = 1 THEN x
    WHEN sortorder = 2 THEN x,y
    END;
 ORDER 
        BY x
         , ... something for sortorder 2

  现在担心的就是sortorder 2。它要求这些行的序列为每个"x"值中的"y"列值。

  但是如果我们只做下面的事情:

ORDER 
        BY x
         , y

  如果sortorder是2,那么这些行的序里为 x"里的"y",这样一切就准备就绪了。但是如果sortorder是1,这些行的序里仍为 x"里的"y",当然他们的序列都为"x"。所以这样也行,不是吗?
你根本就不用CASE表达式。

 
查看全文
 
 
 
 
 

Oracle SQL

 
Oracle Application Express(Oracle APEX)设计的一个主要目标是:快速构建基于Oracle数据库的Web应用程序。
 
SELECT子句通常是一个SELECT语句的第一个子句。它标识出你所想要包含到结果集中的列。这些列是从在FROM子句中指定的基表中返回的。
 
没有ORDER BY子句,Oracle不会保证行显示的顺序。它们可能是按照你想要的顺序排列,但也可能不是。
 
Toad For Oracle的产品策略就是为Oracle开发一款工具,它可以满足不同人的不同需求,比如DBA、开发人员、分析师以及管理者等等。
 
据Toad For Oracle产品经理John Pocknell所说,这次发布的Toad 10致力于生产力的概念,其中包括了:灵活性、易用性、自动化和协作等内容。
 

登录TechTarget中国

关闭
本服务仅向TechTarget中国的会员开放,请登录或立即免费注册
电子邮件地址:
请输入您的电子邮件地址
密码:
下次自动登录