数据库——排序与分页

导读:本篇文章讲解 数据库——排序与分页,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

目录

排序数据

单列排序

多列排列

分页 

 分页原理

优点

 MySQL 8.0新特性


排序数据

  • 使用 ORDER BY 子句排序
  • ASC(ascend): 升序
  • DESC(descend):降序
  • ORDER BY 子句在SELECT语句的结尾。

单列排序

SELECT employee_id,last_name, salary
FROM employees
ORDER BY salary DESC;    # 降序排列
# ORDER BY salary ASC;     # 升序排列,结果差不多,就不展示了,默认升序排列

运行结果如下所示:

数据库——排序与分页

        还可以使用列的别名来排序,具体如下所示:

SELECT employee_id,last_name, salary * 12 AS annual_sal
FROM employees
ORDER BY annual_sal;    # 利用别名来排序

运行结果如下所示:

数据库——排序与分页

        注:只能在ORDER BY中使用,不能在WHERE中使用,而且WHERE语句一定要在ORDER BY之前。

        原因:先执行SELECT语句以及ORDER BY语句之间的语句,再执行SELECT语句,最后执行ORDER BY语句

SELECT employee_id,last_name, salary
FROM employees
WHERE department_id IN (10,20)    # 部门为10,20的人,工资按升序排列
ORDER BY salary;

 运行结果如下所示:

数据库——排序与分页


多列排列

SELECT employee_id,last_name, salary
FROM employees
ORDER BY salary DESC, employee_id;    # salary降序,employee_id 升序

  运行结果如下所示:

数据库——排序与分页

分页 

 分页原理

        所谓分页显示,就是将数据库中的结果集,一段一段显示出来需要的条件。

优点

        约束返回结果的数量可以 减少数据表的网络传输量 ,也可以 提升查询效率 。如果我们知道返回结果只有 1 条,就可以使用 LIMIT 1 ,告诉 SELECT 语句只需要返回一条记录即可。这样的好处就是 SELECT 不需 要扫描完整的表,只需要检索到一条符合条件的记录即可返回。

MySQL中使用 LIMIT 实现分页

格式: LIMIT [位置偏移量,] 行数

        第一个“位置偏移量”参数指示MySQL从哪一行开始显示,是一个可选参数,如果不指定“位置偏移 量”,将会从表中的第一条记录开始(第一条记录的位置偏移量是0,第二条记录的位置偏移量是 1,以此类推);第二个参数“行数”指示返回的记录条数。

SELECT employee_id,last_name, salary
FROM employees
LIMIT 0,2;    # 偏移量为0,显示两条数据

运行结果如下所示:

数据库——排序与分页

分页显式公式:(当前页数-1)*每页条数,每页条数

SELECT employee_id,last_name, salary
FROM employees
LIMIT 2,2;    # 第二页

运行结果如下所示:

数据库——排序与分页

声明顺序

注:LIMIT 子句必须放在整个SELECT语句的最后,如下所示! 

SELECT employee_id,last_name, salary
FROM employees
WHERE salary > 6000
ORDER BY salary DESC
LIMIT 0,10;

运行结果如下所示:

数据库——排序与分页

 MySQL 8.0新特性

        MySQL 8.0中可以使用“LIMIT 3 OFFSET 4”,意思是获取从第5条记录开始后面的3条记录,和“LIMIT 4,3;”返回的结果相同,具体如下所示。

SELECT employee_id,last_name, salary
FROM employees
WHERE salary > 6000
ORDER BY salary DESC
LIMIT 10 OFFSET 0;
# 与上图结果一致

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/82316.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!