order by排序语句的用法


数据库中常用order by关键字对结果集进行排序,又可使用desc和asc来进行指定规则的排序。

学习连接

order by FIELD 及其平替函数 的用法

数据库:order by排序语句的用法
MySQL 中文排序 ORDER BY CONVERT(ColumnName USING gbk) 函数
decode函数的几种用法详解
Oracle decode函数
Oracle中decode函数详解

语法

select column_name,column_name 
from table_name 
order by column_name,column_name asc|desc

即:select 列名 from 表名 order by 列名 asc|desc

用法

  • 默认:升序

  • asc:指定列按升序排列

  • desc:指定列按降序排列

  • desc/asc :只对后方的第一个列名有效,其他不受影响,仍是默认的升序。

    • order by 列名A,列名B 则默认列A和列B均按升序排列

    • order by 列名A desc,列名B A列降序,B列升序排列

    • order by 列名A,列名B desc A列升序,B列降序排列

示例

如果一个table名字为FF_REQUEST,每列的数据为
在这里插入图片描述

1、按单个列的值排序
select * from FF_REQUEST order by NO desc

执行后的效果为:

在这里插入图片描述

2、按多个列的值排序
Select * From FF_REQUEST order by NO,MOBILE

执行后的效果为:
在这里插入图片描述

3、按指定的顺序排序

这个之前没有见过

select * from FF_REQUEST order by charindex(NO,'3,5,2')

// 按某个字段指定的顺序 排序
select * from file_info fi where fi.file_id in ("BWT3YrUcaS","0PLmkIAzPC") order by field(file_id,"BWT3YrUcaS","0PLmkIAzPC") 

// 使用case when(mysql支持case when)
SELECT * FROM FF_REQUEST 
ORDER BY 
CASE WHEN NO=3 THEN 1      
     WHEN NO=5 THEN 2
     WHEN NO=2 THEN 3
     ELSE 4
END

// 也可以使用decode函数(oracle支持decode函数)
SELECT * FROM FF_REQUEST ORDER BY decode(no,3,1,5,2,2,3,4)

执行后的效果为:
在这里插入图片描述

4、按中文拼音字母顺序

在MySQL中,我们经常会对一个字段进行排序,若不是中文字段则可以使用 ORDER BY ColumnName,但进行中文字段排序,对汉字的排序结果往往都是错误的。 这是因为 ORDER BY 是根据对应字符的ASCII码排序

如要实现按照中文拼音的排序,不想改变数据库结构的话,简单的做法是,在SQL语句内加入CONVERT 函数即可。
SELECT * FROM table ORDER BY CONVERT( ColumnName USING gbk);

对比结果如下图:
在这里插入图片描述

5、Order by和where条件共用

Order by必须在where条件之后使用,否则会报错

示例:

select * from FF_REQUEST where to_char(CR_DATE,YYYY-MM-DD) =2019-03-20order by CR_DATE,ID desc

select * from FF_REQUEST where to_char(CR_DATE,YYYY-MM-DD) =2019-03-20order by CR_DATE desc,ID asc
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值