零基础入门 SQL 系列之(二)排序

单列排序

SELECT prod_name 
FROM products 
ORDER BY prod_name;

当我们不明确指定排序的顺序时,MySQl 默认按照升序排序。效果和我们明确指定升序是一样的,如果要明确指定按照升序排序,我们只要在需要排序的字段后面指定 ASC

SELECT prod_name 
FROM products 
ORDER BY prod_name ASC;

和升序相对应的,我们可以进行降序排序。语法和升序一样,只不过 ASC 改成 DESC

SELECT prod_name 
FROM products 
ORDER BY prod_name DESC;

多列排序

指定排序顺序的关键字(ASC、DESC)只对位于其后面的列名起作用,如果想在多个列上进行降序排序,必须对每一列指定排序关键字。

SELECT prod_price, prod_name 
FROM products 
ORDER BY prod_price DESC, prod_name DESC;

用非查询的列排序数据

上面的排序,ORDER BY 后面跟的列都是我们要查询的列,实际上,用非查询的列排序数据也是可以的。

SELECT prod_name 
FROM products 
ORDER BY prod_price;

使用列的相对位置进行排序

ORDER BY 后面除了跟列名之外,我们还可以使用查询列的相对位置。

SELECT prod_id, prod_price, prod_name 
FROM products 
ORDER BY 2, 3;

优点

不用重复输入列明。

缺点

  • 有可能用错误的列进行排序,特别是在检索列改变后,忘记对order by子句做相应的改动。
  • 如果要进行排序的列不在检索的列中,就不能使用相对位置。

小结

讲述了按单列、多列进行排序。如何指定排序方向。

备注:示例中用到的表和数据可以通过链接(https://github.com/songw/sql)下载。

本系列目录:
零基础入门 SQL 系列之(一)查询数据
零基础入门 SQL 系列之(二)排序
零基础入门 SQL 系列之(三)过滤数据
零基础入门 SQL 系列之(四)内置函数
零基础入门 SQL 系列之(五)数据汇总
零基础入门 SQL 系列之(六)表连接
零基础入门 SQL 系列之(七)组合
零基础入门 SQL 系列之(八)插入、更新、删除
零基础入门 SQL 系列之(九)创建和操作表
零基础入门 SQL 系列之(十)视图

在这里插入图片描述

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值