数据库——排序与分页

目录

排序数据

单列排序

多列排列

分页 

 分页原理

优点

 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;
# 与上图结果一致

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值