MySQL排序检索数据操作方法梳理
前言
本实验中所用数据库创建SQL语句以及插入数据到数据库中的SQL语句链接:
链接: https://pan.baidu.com/s/14q4kBP9vGvbOU_4Ggo07GQ?pwd=4w4y
提取码:4w4y
书接上回说到,mysql检索数据
本篇文章主要介绍如何使用 select 的 MySQL 语言,根据我们的想要排序检索出的数据。
1. 排序数据
检索出的数据不是随机显示的,若不排序,数据以其在表中出现的顺序显示。关系数据库设计理论认为,如果不规定排序顺序,则不能假定检索出的数据的顺序有任何意义。
为了明确地排序用 select 语句检索出的数据,可以使用 order by 字句 取一个或多个列的名字,以此对输出进行排序
如下:
select prod_name
from Products
order by prod_name;
注意: order by 字句的位置一定是 select 语句的最后一条字句,如果不是最后一条字句,将会出错
2. 按多个列排序
通常我们不只需要按单个列排序,而是需要按多个列排序,当第一个列相等时,按第二个列排序…以此类推。这是,我们只需要将需要排序的多个列间用逗号隔开即可。
如下: 先按 prod_price 排序,prod_price 相同时,按照 prod_name 排序
select prod_id, prod_price, prod_name
from Products
order by prod_price, prod_name;
3. 按列位置排序
order by 字句还支持按照列位置进行排序,这种方法的好处是不需要重新输入列名。但是它也有缺点,比如进行排序的列必须在 select 清单中,并且这种方式当 select 清单变化时容易造成错误。
如下:2, 3 分别表示 select 清单中的第二(prod_price),第三列(prod_name)
select prod_id, prod_price, prod_name
from Products
order by 2, 3;
4. 指定排序方式(升序或者降序)
order by 默认为升序排序 (asc),可以通过指定 desc 关键字来实现降序排序
如下: 通过在 order by 字句的最后加上 desc,实现降序排序
select prod_id, prod_price, prod_name
from Products
order by prod_price desc;
思考:当我们需要对多个列降序排序时,应该怎么写呢?
desc 作用域问题: desc 关键字只作用于直接位于其前面的列名,因此若是想要对多个列降序排序,需要在需要降序排序的每个列的最后都加上 desc 关键字
如下: 按照 prod_price 降序排序,当 prod_price 相同时,按照 prod_id 降序排序;同理,当 prod_id 相同时,按照 prod_name 降序排序。
select prod_id, prod_price, prod_name
from Products
order by prod_price desc, prod_id desc, prod_name desc;
注: desc 只作用于直接位于其前面的列名的特点,使得我们可以很好的定制化排序,在需要降序排序的列后加 desc,而其他列仍然可以按照升序排序,这种机制非常灵活。
5. 扩展—文本性数据如何排序
在对文本性数据进行排序时,A与a是否相同;a位于B之前,还是Z之后,取决于数据库的设计方式。
实际上,在字典排序顺序中,A被视为与a相同,大部分数据库也采取这种默认做法。要想改变这种行为,可以求助数据库管理员的帮助,许多DBMS容许数据库管理员改变这种行为。
到此这篇关于MySQL排序检索数据操作方法梳理的文章就介绍到这了,更多相关MySQL检索数据内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341