详解MySQL中Order By多字段排序规则


当前第2页 返回上一页

有比较,才有想法,有比较才有进步,因此我们先把单字段的降序排序结果列出来,然后在看看两个字段的降序排序气矿,我们就可以从中分析出其中道理来。


1

2

3

4

-- 按照name进行降序排序

select * from a order by name desc;

-- 按照code进行降序排序

select * from a order by code desc;

左边是order by name desc, 右边是order by code desc的结果

codename
高二我的
高一我是
高二我们
中一
中二
codename
高二我们
高二我的
高一我是
中二
中一

结果很明显:单一字段排序的时候,其他字段出现的顺序是自然排序的。

下面我们看看多字段的排序


1

2

-- 按照code, name进行降序排序

select * from a order by code, name desc;

codename
中一
中二
高一我是
高二我的
高二我们

结果如下:首先谢谢qq_27837327和MjayTang 的,本人在这里一次测试, 原文说这个sql排序无效的说法是错误的。实际上说order by code,name desc等同于order by code asc, name desc

经测试发现,select * from a order by code and name desc 排序效果依然无效。

我们在看看下面的语句


1

2

3

4

-- 按照code, name进行降序排序

select * from a order by code desc, name desc;

-- 该语句的效果等同于下面的语句, 其中1、2分别对应的是code、name

select code, name from a order by 1 desc, 2 desc;

codename
高二我的
高二我们
高一我是
中二
中一

对比code,name的单个字段降序排序,我们可以发现, 使用 order by code desc, name desc的时候,MySQL会先以code进行降序排序,在code进行降序排序该基础上,再使用name进行降序排序。

另外我们还可以使用contat函数把多个字段拼接起来,在进行排序。但是要保证字段不能为null。下面我们来看一下concat的sql语句和结果。


1

select * from a order by concat(code,name) desc

codename
高二我的
高二我们
高一我是
中二
中一

很明显,在这个测试例子上来看, order by concat(code, name) desc的效果等同于 order by code desc, name desc

相关推荐:

MySQL Order by 语句优化代码详解

mysql中order by in 的字符顺序(推荐)

MySQL Order By用法分享

以上就是详解MySQL中Order By多字段排序规则的详细内容,更多文章请关注木庄网络博客

返回前面的内容

相关阅读 >>

mysql怎么删除库中的所有表

对于mysql在保存时间信息上的建议

mysql 中文乱码解决办法

mysql中关于日期函数汇总

php数据库操作之基于mysqli的数据库操作类库

学习mysql事件如何调用存储过程的方法

带你5分钟读懂mysql字符集设置

mysql神器之show full processlist

mysql如何设置默认值

linux centos7环境下mysql安装教程

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...