MySQL中的LIMIT与ORDER BY关键字详解

前言

众所周知,LIMIT和ORDER BY在数据库中,是两个非常关键并且经常一起使用的SQL语句部分,它们在数据处理和分页展示方面发挥着重要作用。

今天就结合工作中遇到的实际问题,回顾一下这块的知识点。同时希望这篇文章可以帮助到正在学习,及复习这块知识的大佬!

LIMIT 关键字

LIMIT关键字的作用是限制查询结果集返回的记录数。比如说我们要查询数据库表的时候,执行SQL语句返回了大量的List,这个时候就可以使用Limit关键字限制查询数据库返回的条数。

Limit关键字的基本语法

sql 复制代码
SELECT column1, column2, ...  
FROM table_name  
WHERE condition  
ORDER BY column_name  
LIMIT offset, count;
  • offset:在上面的代码里,注意offset是可选的,它是指定结果从哪一条记录开始返回,第一条记录的偏移量为0。如果省略offset,则默认从第一条记录开始(offset为0)。
  • count:count代表每页的的记录条数。

如果想要结果集从索引为0的行数开始,每页的大小为10条,那么语句为:

sql 复制代码
limit 0, 10;

上面这个分页是第一页,第二页:

sql 复制代码
limit 10, 10;

以此类推...

第三页

sql 复制代码
limit 20, 10;

第四页

sql 复制代码
limit 30, 10;

根据上面结果我们可以总结出规律,分页查询的公示可以推出来:

sql 复制代码
limit (index - 1) * count, count

但是需要注意亿点!当LIMIT与OFFSET这对"cp"一起使用时,随着OFFSET的增大,查询性能可能会逐渐下降,毕竟数据库需要扫描更多的行才能定位到起始点。

同时,在使用LIMIT关键字对数据分页时,经常先对数据进行排序(使用ORDER BY关键字),这样得出的结果才会有序。

ORDER BY 关键字

ORDER BY关键字的作用是对查询结果集进行排序。它可以基于一个或者多个列对结果进行升序(ASC)或降序(DESC)排序。

基本语法如下:

sql 复制代码
SELECT column1, column2, ...  
FROM table_name  
WHERE condition  
ORDER BY column_name1 ASC|DESC, column_name2 ASC|DESC, ...;

ASC:升序排序(如果没有指定的话,默认值是升序)。

DESC:降序排序。

当使用多个列进行排序时,MySQL会按照ORDER BY子句中列的顺序依次进行排序。如果前面的列有相同的值,会按照后面的列进行排序

其次,如果查询涉及大量数据,并且也没有使用索引进行排序,那么排序操作可能会比较耗时。所以,在使用-排序功能的时候,可以为排序列创建索引来提高查询效率。

LIMIT与ORDER BY的协同工作

在实际的项目应用中,LIMIT和ORDER BY经常一起使用,共同实现有序的分页显示。通过ORDER BY对查询结果进行排序,然后通过LIMIT限制返回的记录数。这样,两两搭配,干活不累!!!

但是最近结合Java代码查询数据的时候,在MyBatis的XML文件中使用SQL查询数据库的时候出现了明显的错误,这里和大家分享下。

具体的详细代码如下:

#{}会自动转义特殊字符,可以防止SQL注入,而对于${},它不会进行转义处理 。但是在debug代码过后,发现上面的这种写法是错误的,最好是在Java代码中把Limit后面的结果值算出来后直接传入到XML中,而不是在XML中进行加减乘除做运算。因为 MyBatis 不会执行 Java 表达式

所以我们要修正 limit 语句,提前在Java代码中计算偏移量:

java 复制代码
// 在 Java 代码中  
int offset = (page.getCurrentPage() - 1) * page.pageSize();  
// 然后传递 offset 和 pageSize 到 MyBatis 映射中

在 MyBatis XML 中:

xml 复制代码
<if test="page.currentPage != null and page.pageSize != null">  
  limit #{offset}, #{page.pageSize}  
</if>

这样的话,就可以确保所有传入的参数都是安全的,避免SQL 注入。

文章总结

So,LIMIT和ORDER BY是MySQL中两个非常重要的关键字,它们在数据处理和结果集控制方面发挥着关键作用。我们在项目中还是要多使用这两个关键字,毕竟可以提高查询效率,优化用户体验。

本篇文章到这里就结束了,后续会继续分享相关的知识,感谢各位小伙伴们的支持!

相关推荐
heartbeat..3 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
麦聪聊数据5 小时前
MySQL并发与锁:从“防止超卖”到排查“死锁”
数据库·sql·mysql
AC赳赳老秦6 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek
myzshare7 小时前
实战分享:我是如何用SSM框架开发出一个完整项目的
java·mysql·spring cloud·微信小程序
YMatrix 官方技术社区7 小时前
YMatrix 存储引擎解密:MARS3 存储引擎如何超越传统行存、列存实现“时序+分析“场景性能大幅提升?
开发语言·数据库·时序数据库·数据库架构·智慧工厂·存储引擎·ymatrix
辞砚技术录8 小时前
MySQL面试题——索引2nd
数据库·mysql·面试
linweidong8 小时前
C++thread pool(线程池)设计应关注哪些扩展性问题?
java·数据库·c++
墨笔之风8 小时前
java后端根据双数据源进行不同的接口查询
java·开发语言·mysql·postgres
欧亚学术9 小时前
突发!刚刚新增17本期刊被剔除!
数据库·论文·sci·期刊·博士·scopus·发表
黑白极客9 小时前
怎么给字符串字段加索引?日志系统 一条更新语句是怎么执行的
java·数据库·sql·mysql·引擎