ORDER By子句中的CASE表达式

2008-12-3    | |
打印本文章
RSS

导读:在ORDER BY用CASE表达式是一种技巧,这种技巧能让我们在列表中的自然值自身不能满足任务时进行习惯性排序。Oracle专家在本文中列举出了两个例子进行了解释。

关键词:ORDER By CASE CASE表达式 Oracle开发语言

正在加载数据... 【TechTarget中国原创】前几天我阅读了一些有关在SELECT语句ORDER BY子句中用CASE表达式的一些指南。你能列举一些简单的例子解释一下吗?答:在ORDER BY用CASE表达式是一种技巧,这种技巧能让我们在列表中的自然值自身不能满足任务时进行习惯性排序。我将列举出两个例子。

【TechTarget中国原创】问:前几天我阅读了一些有关在SELECT语句ORDER BY子句中用CASE表达式的一些指南。你能列举一些简单的例子解释一下吗?

  答:在ORDER BY用CASE表达式是一种技巧,这种技巧能让我们在列表中的自然值自身不能满足任务时进行习惯性排序。我将列举出两个例子。

  第一个例子所表达的情况就是当人力资源部想根据职位查看工资单的时候,首先要除开销售人员、其次就是IT职员、第三就是管理人员、最后是其他人,当然包括工资列表上的团队中的每个人。

  CASE表达式用来将职位“转化”成值满足sort sequence的需求。


SELECT position
         , empno
         , salary
      FROM personnel
    ORDER
        BY CASE 
             WHEN position = 'sales' THEN 1
             WHEN position = 'it'    THEN 2
             WHEN position = 'mgmt'  THEN 3
                                     ELSE 4 END

  CASE表达式实际上在表中其他的列上创建了一个单独的附加列。CASE表达式还会更给每行计算附加列值。这个附加列还会对结果集进行排序,但是它并没有返回到不是结果集中(除非你在SELECT子句中还包括CASE表达式)。由于职位名称排序不正确,不是ASC也不是DESC或他们本身,所以我们还是需要CASE表达式。
第二个例子很相似:


ELECT position
         , empno
         , salary
      FROM personnel
    ORDER
        BY CASE 
             WHEN position = 'sales' THEN 'Curly'
             WHEN position = 'it'    THEN 'Larry'
             WHEN position = 'mgmt'  THEN 'Moe'
                                     ELSE 'Shemp' END
         , salary DESC

  你能理解了吗?

查看全文
相关的白皮书
 
如何创建数据连接?如何导出或导入数据库连接?怎样浏览数据库对象?本文针对上述几个问题详细介绍如何使用SQL Developer来操作Oracle数据库。
 
Oracle SQL Developer是一款怎样的工具?它具有什么功能?本文主要介绍如何使用SQL Developer来操作Oracle数据库。
 
如何查看手册?如何查找信息?如何使用Oracle数据库SQL参考手册?本文针对上述问题通过图例进行了详细阐述。
 
如何打开并保存SQL语句?如何输入并执行一个SQL脚本?本文侧重介绍使用SQL Developer执行SQL语句的过程中的这两个问题。
 
在使用SQL Developer执行SQL语句的过程中我们如何使用摘录窗口?如何处理语法错误?
在SQL Server中,我们如何进行索引设计来提升系统的性能和对查询进行优化,是许多用户非常关注的问题,在本次技术专题中,我们将分群集索引和非群集索引设计两部分来为您详细分析。
本技术专题主要为使用Oracle SQL Developer和其他开发工具。包括如何使用Oracle SQL Developer和其他开发工具、使用Oracle Database Home Page、在Oracle中使用SQL*Plus等方面。
本专题为QL SELECT语句基础。侧重概述了如何使用SELECT来访问SQL数据库中所有内容以及组成SELECT语句的许多子句名称和功能;同时还阐述了如何使用DISTINCT关键字消除重复的行,以及如何正确使用ORDER BY子句来排序数据。
最新更新
专家答疑
技巧
Brian Fedorko
Oracle数据库审计功能十分强大、灵活并且易于配置,适当并有效地使用数据库审计功能是拥有高效安全策略的基础。
Brian Peasland
Oracle数据库二进制文件和库文件是高版本版本的,而备份的数据库内部如果仍然是较低版本,那么Oracle将不允许你打开数据库,除非你完成了升级过程。
Maria Anderson
在Windows XP环境下,使用数据库升级助手将Oracle从9.2.0.1升级到10g R2,出现DBUA不能识别Oracle数据库的SID问题如何解决。

登录TechTarget中国

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