第05章_排序与分页

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 ; 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值