1. 排序数据

1.1 排序规则

  • 使用 ORDER BY 子句排序

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

1.2 单列排序

SELECT   last_name, job_id, department_id, hire_date
FROM     employees
ORDER BY hire_date ;

SELECT   last_name, job_id, department_id, hire_date
FROM     employees
ORDER BY hire_date DESC ;

SELECT employee_id, last_name, salary*12 annsal
FROM   employees
ORDER BY annsal;

1.3 多列排序

SELECT last_name, department_id, salary
FROM   employees
ORDER BY department_id, salary DESC;

  • 可以使用不在SELECT列表中的列排序。
  • 在对多列进行排序的时候,首先排序的第一列必须有相同的列值,才会对第二列进行排序。如果第一列数据中所有值都是唯一的,将不再对第二列进行排序。

2. 分页

2.1 背景

背景1:查询返回的记录太多了,查看起来很不方便,怎么样能够实现分页查询呢?

背景2:表里有 4 条数据,我们只想要显示第 2、3 条数据怎么办呢?

2.2 实现规则

  • 分页原理

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

  • MySQL中使用 LIMIT 实现分页

  • 格式:

    LIMIT [位置偏移量,] 行数
    

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

  • 举例

--前10条记录:
SELECT * FROM 表名 LIMIT 0,10;
或者
SELECT * FROM 表名 LIMIT 10;--第11至20条记录:
SELECT * FROM 表名 LIMIT 10,10;--第21至30条记录:
SELECT * FROM 表名 LIMIT 20,10;

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

  • 分页显式公式**:(当前页数-1)每页条数,每页条数*
SELECT * FROM table
LIMIT(PageNo - 1)*PageSize,PageSize;
  • 注意:LIMIT 子句必须放在整个SELECT语句的最后!
  • 使用 LIMIT 的好处

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

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 rownum, last_name,salary
FROM (SELECT last_name,salaryFROM employeesORDER BY salary DESC)
WHERE rownum < 10;

得到与上述方法一致的结果。

SQL语句排序与分页相关推荐

  1. SQL语句排序、分页、多表查询

    一.排序 1.1 排序规则 使用 ORDER BY 子句排序 ASC(ascend): 升序 DESC(descend):降序 ORDER BY 子句在SELECT语句的结尾. 1.2 单列排序 SE ...

  2. sql语句转化为分页查询的一种实现

    /*** 将sql语句转化为分页查询** */public static String addfy4oracle(String sql, int start, int limit, List args ...

  3. oracle分页查询sql语句通用,oracle分页查询sql语句,oracle分页查询sql语句详解

    oracle分页查询sql语句,oracle分页查询sql语句详解,Oracle分页查询sql语句 Oracle中分页和MySql中的分页不同,MySql中的分页使用关键字limit即可,相对简单一点 ...

  4. 一个利用sql 语句来实现分页的存储过程

    最近一直在研究存储过程和函数,感觉这趟水有点浑,所以我决定要趟这趟浑水. 一些是一个sql server的分页存储过程,可以结合页面设计来进行理解 假设场景有,上一页 下一页两个按钮,排序方式悬着下拉 ...

  5. 通过sql语句查询实现分页

    通过sql语句分页 如:SELECT * FROM users limit 3,2 从第4条记录开始后续显示两行,索引从0开始 (服务器机制)该方式的优缺点如下:   优点:操作便捷(利用服务器内存) ...

  6. mybatis mysql 分页sql语句_MySql实现分页查询的SQL,mysql实现分页查询的sql语句(转)...

    http://blog.csdn.net/sxdtzhaoxinguo/article/details/51481430 摘要:MySQL数据库实现分页查询的SQL语句写法! 一:分页需求: 客户端通 ...

  7. 用SQL语句进行数据分页查询

    今天给大家来分享一个分页方法,希望对一些同行有帮助,方法如下:  第一个参数就是你正常查询数据库的语句: 第二个参数就是根据哪一列进行排序: 第三个参数就是查询第几页: 第四个参数就是一页多少条数据: ...

  8. oracle中sql语句排序,Oracle SQL排序方式与case语句

    我在理解带有case语句的oracle(12c)sql order by子句时遇到困难.我有一张包含以下数据的表格, SELECT DEPT_NO, DEPT_NAME FROM SORTNG_LOG ...

  9. SQL语句排序中null值的处理

    1.不加"关照"的order by升序排序效果–NULL值在后. sec@ora10g> select * from t order by x; X 1234 7 rows ...

最新文章

  1. 平均股价的时间序列图形_美股技术分析 神奇的九转序列
  2. Java并发编程实战 第4章 对象的组合
  3. 【学会如何学习系列】从婴儿到大学——学习的本质从未改变过
  4. 【软件开发底层知识修炼】二十七 C/C++中的指针与数组是不同的
  5. python爬取天气数据山东_Python的学习《山东省各城市天气爬取》
  6. 【java】java boolean 源码分析
  7. 任务调度 QUARTZ
  8. 【安全资讯】热门Windows激活软件KMSPico被植入恶意程序
  9. matlab爱心函数代码画图
  10. FFMPEG硬件编解码器使用
  11. origin数据平滑_科学网—关于origin曲线平滑处理 lowess - 叶小球的博文
  12. Python读写欧姆龙PLC(本工作是由具体项目而开展的)
  13. WIN7下安装WIN2003系统
  14. js高阶函数的使用-filter/map/reduct
  15. 微信朋友圈点赞设计测试用例
  16. 当你发呆时,大脑在做什么?
  17. 2022年10月17日【Jiawei_Z】WPF的容器章节
  18. python warning
  19. Python语言程序设计基础科学计算与可视化小练习
  20. 利用pandas整理订单,并根据地址对比进行分类

热门文章

  1. 火山安卓窗口组件操作组件布局类
  2. JSON数据造假和解析
  3. 日常工作报告生成器微信小程序源码/支持日报、周报、月报、年终终结
  4. mysql数据如何恢复到任意时间节点?mysql数据恢复,mysql数据备份
  5. VS2008环境使用MFC操作读取excel文件
  6. 标志寄存器CF,OF,SF,ZF,PF以及相关练习
  7. python实验目的_实验五 Python文件操作实验
  8. JS小案例--关于时间--限时购
  9. 使用Python和Mask R-CNN自动寻找停车位,这是什么神操作?
  10. 2020年数据术语的故事