Rumah > pangkalan data > tutorial mysql > 详解MySQL中Order By多字段排序规则

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

小云云
Lepaskan: 2017-12-14 11:54:25
asal
4321 orang telah melayarinya

想了解一下mysql order by排序是以什么规则进行的? 本文主要介绍了MySQL中Order By多字段排序规则代码示例,小编觉得挺不错的,这里给大家分享下,需要的朋友可以参考,希望能帮助到大家。

MySql order by 单字段

建一测试表如下:


CREATE TABLE `a` ( 
 `code` varchar(255) DEFAULT NULL, 
 `name` varchar(255) DEFAULT NULL 
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Salin selepas log masuk


INSERT into a values('中一', '我'); 
INSERT into a values('中二', '你'); 
INSERT into a values('高一', '我是'); 
INSERT into a values('高二', '我们'); 
INSERT into a values('高二', '我的');
Salin selepas log masuk

测试语句如下:


-- hex(): 获取16进制字节码 
select name, hex(name) from a order by name desc
Salin selepas log masuk

结果如下:

namehex(name)
我的E68891E79A84
我是E68891E698AF
我们E68891E4BBAC
E68891
E4BDA0

很明显,MySQL中的排序,是以字节码进行排序的,当第一个字相同的时候,比较第二个字的字节码, 一次类推

MySql order by 多字段

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


-- 按照name进行降序排序 
select * from a order by name desc; 
-- 按照code进行降序排序 
select * from a order by code desc;
Salin selepas log masuk

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

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

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

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


-- 按照code, name进行降序排序 
select * from a order by code, name desc;
Salin selepas log masuk
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 排序效果依然无效。

我们在看看下面的语句


-- 按照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;
Salin selepas log masuk
codename
高二我的
高二我们
高一我是
中二
中一

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

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


select * from a order by concat(code,name) desc
Salin selepas log masuk
code name
高二 我的
高二 我们
高一 我是
中二
中一

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

相关推荐:

MySQL Order by 语句优化代码详解

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

MySQL Order By用法分享

Atas ialah kandungan terperinci 详解MySQL中Order By多字段排序规则. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan