MySQL下limit和join的优化建议

在大数据量下,MySQL的limit操作可能导致性能下降,尤其是当m值较大时。通过减少m值或者利用主键和索引来优化查询,如`limit n`或`where id >= x limit n`。此外,join操作中应考虑用小表驱动大表,并估计结果集大小,合理放置条件以提升性能。
摘要由CSDN通过智能技术生成

PHP中分页肯定会使用到MySQL的limit,大部分对类似"select * from title where uid =** order by id desc limit m,n"很熟悉,也不是全部都能看出里面有什么不对,可是当是在大数据量下操作呢,比如百万类似"select * from title where uid =177 order by id desc limit 1234567,20"就会发现sql执行的时间明显变得很长,为什么呢?

先从MySQL的limit原理说起,使用limit m,n是时候,MySQL先扫描(m+n)条记录,然后从m行开始取n行.比如上面的例子就是先扫描1234587条数据,这样的话sql能快吗?这就要求我们尽可能的减少m的值,甚至没有m直接limit n这样是sql.

看个例子:

mysql> select id,substr(mobile from 1 for 7),time,cpid,linkid from cp_mo100227 where cpid=769 limit 888888,10;
+----------+-----------------------------+---------------------+------+----------------------+
| id       | substr(mobile from 1 for 7) | time                | cpid | linkid               |
+----------+-----------------------------+---------------------+------+----------------------+
| 11535090 | 1353554                     | 2010-02-24 21:07:48 |  769 | 2106490590330958

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值