文章目录
- 学习连接
- 语法
- 用法
- 示例
- 1、按单个列的值排序
- 2、按多个列的值排序
- 3、按指定的规则排序
- 4、按中文拼音字母顺序
- 5、Order by和where条件共用
数据库中常用order by关键字对结果集进行排序,又可使用desc和asc来进行指定规则的排序。
学习连接
数据库:order by排序语句的用法
MySQL 中文排序 ORDER BY CONVERT(ColumnName USING gbk) 函数
语法
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')
执行后的效果为:
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-20’ order by CR_DATE,ID desc
select * from FF_REQUEST where to_char(CR_DATE,YYYY-MM-DD) =’2019-03-20’ order by CR_DATE desc,ID asc