1. 排序数据
1.1 排序规则
使用 ORDER BY 子句排序
ASC(ascend): 升序
DESC(descend):降序
ORDER BY 子句在SELECT语句的结尾。
.2 单列排序
按照salalry从高到低
SELECT last_name,salary
FROM employees
#order by salary DESC;
ORDER BY salary ;#没有显示排序方式的话,就默认是升序
1.3 多列排序
- 可以使用不在SELECT列表中的列排序。
- 在对多列进行排序的时候,首先排序的第一列必须有相同的列值,才会对第二列进行排序。如果第一列数据中所有值都是唯一的,将不再对第二列进行排序。
-
4.二级排序 #按照department_id降序,salary进行升序 SELECT last_name,department_id,salary FROM employees ORDER BY department_id DESC,salary ASC;
2. 分页
-
2.2 实现规则
分页原理
所谓分页显示,就是将数据库中的结果集,一段一段显示出来需要的条件。
MySQL中使用 LIMIT 实现分页 -
格式:
LIMIT 位置偏移量, 行数# LIMIT 偏移量,条目数 SELECT employee_id,last_name,salary FROM employees LIMIT 0,20;
分页显式公式:(当前页数-1)*每页条数,每页条数:
- 注意:LIMIT 子句必须放在整个SELECT语句的最后!
- where.... Order by ....limit 声明顺序
- 使用 LIMIT 的好处:
约束返回结果的数量可以 减少数据表的网络传输量 ,也可以 提升查询效率 。 -
2.3 拓展
在不同的 DBMS 中使用的关键字可能不同。在 MySQL、PostgreSQL、MariaDB 和 SQLite 中使用 LIMIT 关键字,而且需要放到 SELECT 语句的最后面
- 如果是 SQL Server 和 Access,需要使用 TOP 关键字,比如:
-
SELECT TOP 5 name, hp_max FROM heros ORDER BY hp_max DESC
- 如果是 DB2,使用 FETCH FIRST 5 ROWS ONLY 这样的关键字:
SELECT name, hp_max FROM heros ORDER BY hp_max DESC FETCH FIRST 5 ROWS ONLY
- 如果是 Oracle,你需要基于 ROWNUM 来统计行数:
-
SELECT rownum,last_name,salary FROM employees WHERE rownum < 5 ORDER BY salary DESC; #需要说明的是,这条语句是先取出来前 5 条数据行,然后再按照 hp_max #从高到低的顺序进行排序。但这样产生的结果和上述方法的并不一样。 #在后面讲到子查询,你可以使用 SELECT last_name,salary FROM employees ORDER BY salary DESC) WHERE rownum < 10; #得到与上述方法一致的结果。
2.3 mysql80的新特性 LIMIT...OFFSET
-
#2.3 mysql80的新特性 LIMIT...OFFSET SELECT employee_id,last_name,salary FROM employees LIMIT 2 OFFSET 31;
3.课后练习
#第05章 排序与分页练习题 SELECT *FROM employees; #1. 查询员工的姓名和部门号和年薪,按年薪降序,按姓名升序显示 SELECT last_name,department_id,salary*12 sall FROM employees ORDER BY sall DESC,last_name ASC; #2. 选择工资不在 8000 到 17000 的员工的姓名和工资,按工资降序,显示第21到40位置的数据 SELECT last_name,salary FROM employees WHERE NOT salary BETWEEN 8000 AND 17000 ORDER BY salary DESC LIMIT 20,20; #3. 查询邮箱中包含 e 的员工信息,并先按邮箱的字节数降序,再按部门号升序 SELECT last_name,salary FROM employees # where email like '%e%' WHERE email REGEXP '[e]' ORDER BY LENGTH(email) DESC,department_id ;