SQL必知必会(第四版)-3.排序检索数据(ORDER BY)

目录

3.排序检索数据

3.1 排序数据

3.2 按多个列排序

3.3 按列位置排序

3.4 指定排序方向


3.排序检索数据

3.1 排序数据

子句(clause):SQL语句由子句构成,有些子句是必需的,有些则是可选的。一个子句通常由一个关键字加上所提供的数据组成。子句的例子有我们在前一课看到的SELECT语句的FROM子句。

为了明确地排序用SELECT语句检索出的数据,可使用ORDER BY子句。

ORDER BY子句取一个或多个列的名字,据此对输出进行排序。

在指定一条ORDER BY子句时,应该保证它是SELECT语句中最后一条子句。如果它不是最后的子句,将会出现错误消息。

用非检索的列排序数据也是完全可以的。(即,用不是SELECT选出的列来排序也是可以的)

3.2 按多个列排序

下面的代码检索3个列,并按其中两个列对结果进行排序——首先按价格,然后按名称排序。

3.3 按列位置排序

除了能用列名指出排序顺序外,ORDER BY还支持按相对列位置进行排序。

ORDER BY 2表示按SELECT清单中的第二个列prod_name进行排序。ORDER BY 2,3表示先按prod_price,再按prod_name进行排序。

  • 优点:不用重新输入列名
  • 缺点:1. 不明确给出列名有可能造成错用列名排序;2. 在对SELECT清单进行更改时容易错误地对数据进行排序(忘记对ORDER BY子句做相应的改动);3. 如果进行排序的列不在SELECT清单中,显然不能使用这项技术。

如果有必要,可以混合匹配使用实际列名和相对列位置。

3.4 指定排序方向

默认升序排序:ASC(或ASCENDING)

如需改为降序排序,使用DESC(或DESCENDING)关键字。例如:

  • 以价格降序来排序产品(最贵的排在最前面)

       

  • 对多个列排序(对一列降序,一列升序):

       DESC关键字只应用到直接位于其前面的列名。prod_price列以降序排序,而prod_name列(在每个价格内)仍然按标准的升序排序。

       如果想在多个列上进行降序排序,必须对每一列指定DESC关键字。

在对文本性数据进行排序时,A与a相同吗?a位于B之前,还是Z之后?这些问题不是理论问题,其答案取决于数据库的设置方式。如果确实需要改变这种排序顺序,用简单的ORDER BY子句可能做不到。你必须请求数据库管理员的帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值