使用limit效率的问题和优化

LIMIT用来返回SELECT语句的行数。LIMIT取1个或2个数字参数,如果给定2个参数,第一个指定要返回的第一行的偏移量,第二个指定返回行的最大数目。初始行的偏移量是0(不是1)。
 

    LIMIT在可以很方便的返回所需的数据,数据量小(10W以下)时,效率这方面不会有太大的问题,但数据量一大就会导致性能的下降。下面是我的测试数据:都是在20W条记录的数据表中运行

实例:stockout_order 表中共有350w的数据,分别查询第3K条数据和第30W条。

当数据量大于10w时,

<span style="font-size:12px;">mysql> select count(1) from stockout_order;
+----------+
| count(1) |
+----------+
|  3545570 |
+----------+
1 row in set (0.54 sec)</span>

select stockout_no from stockout_order limit 3000,1;

<span style="font-size:12px;">mysql> select stockout_no from stockout_order limit 3000,1;
+----------------+
| stockout_no    |
+----------------+
| CK201409213726 |
+----------------+
1 row in set (0.00 sec)</span>

select stockout_no from stockout_order where stockout_id >=3000 limit 1;

mysql> select stockout_no from stockout_order where stockout_id >=3000 limit 1;
+----------------+
| stockout_no    |
+----------------+
| CK201409202895 |
+----------------+
1 row in set (0.01 sec)


select stockout_no from stockout_order limit 3000000,1;

mysql> select stockout_no from stockout_order limit 3000000,1;
+---------------+
| stockout_no   |
+---------------+
| CK20150803580 |
+---------------+
1 row in set (2.06 sec)

select stockout_no from stockout_order where stockout_id >3000000 limit 1;

mysql> select stockout_no from stockout_order where stockout_id >=3000000 limit 1;
+----------------+
| stockout_no   |
+----------------+
| CK201508022484 |
+----------------+
1 row in set (0.01 sec)




 

比较以上的数据时,我们可以发现采用where...limit....性能基本稳定,受偏移量和行数的影响不大,而单纯采用limit的话,受偏移量的影响很大,当偏移量大到一定后性能开始大幅下降。不过在数据量不大的情况下,两者的区别不大,使用哪种就是个人的兴趣了。

http://www.server110.com/mysql/201310/2228.html


在数据库查询中,LIMIT是一种用于限制查询结果集返回的行数的语句。根据引用的数据分析,如果limit限制的行数在已有的数据范围内,查询的效率不会受到影响,因为只需要返回指定数量的行即可。但是,如果limit限制的行数超过了已有的数据范围,可能会导致全表扫描,并且查询的耗时会增加。引用提到,当同时使用GROUP BY和LIMIT时,会导致所有数据进行扫描重排,影响查询效率。 此外,根据引用的解释,如果限制的行数无法在已有的数据中满足,则会继续检索整个表的数据,这可能会增加查询的时间。 因此,LIMIT使用在一定程度上会影响查询的效率。如果limit限制的行数在已有的数据范围内,则查询效率不会受影响;如果limit限制的行数超过了已有的数据范围,可能会导致全表扫描并增加查询时间。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [MySQL实战—— Limit与Order by 对查询效率的巨大影响](https://blog.csdn.net/zhibo_lv/article/details/117846795)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [MySQL踩坑之-- group by 和 limit 组合使用效率优化](https://blog.csdn.net/qq_33492197/article/details/124689420)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值