如果你认为不是,就加个子查询:
select from (select from tabel as tb order by tbprice desc) temp_table limit 0,20。使用子查询优化大数据量分页查询
这种方式的做法是先定位偏移位置的id,然后再往后查询,适用于id递增的情况。
使用id限定优化大数据量分页查询
使用这种方式需要先假设数据表的id是连续递增的,我们根据查询的页数和查询的记录数可以算出查询的id的范围,可以使用 id between and 来查询:
当然了,也可以使用in的方式来进行查询,这种方式经常用在多表关联的情况下,使用其他表查询的id集合来进行查询:
但是使用这种in查询方式的时候要注意的是,某些MySQL版本并不支持在in子句中使用limit子句。
参考 sql优化之大数据量分页查询(mysql) - yanggb - 博客园 (cnblogscom)SELECT FROM table LIMIT [offset,] rows;
offset :偏移,从 offset 条之后开始选择数据,如果 offset 不填,则 offset 为0。
rows :从偏移后开始,选择 rows 条数据。
特点:左开右闭,即选取 (offset,offset+rows] 的数据。
SELECT FROM table LIMIT 5;
SELECT FROM table LIMIT 0,5;
区间:(0,5]
offset=0
rows=5-0=5
SELECT FROM table LIMIT 2,4;
区间:(1,5]
offset=1
rows=5-1=4
SELECT FROM table LIMIT n,m;
区间:(n-1,m]
offset=n-1
rows=m-n+1您可以使用LIMIT 语句
SELECT id,
name,
work
FROM
frmb_newbiesfrmb_config
LIMIT 0, 50;
如上面的这个语句 LIMIT 后的第一个参数就是 页码编号 第二个参数50就是一个页显示多少条数据
也就是说当你的 0修改为1的时候就是第二页的数据了~
所以只要在您的数据后面 加上 LIMIT语句就可以了首先你知道limit 的两个参数吧,如果limit 0,5 就是取前六条,具体跳转到多少页,是要经过计算的,比如说你一页显示5条,想跳转第二页,那么查询的数据应该是第6条到第10条对吧,然后limit 5,9。这个不是数据库 *** 作啦,是算数问题咯。
MySQL中分页实现
mysql
--------
|pname|
--------
|产品1|
|产品2|
|产品三|
--------
3rowsinset(000sec)
这个地方是说,从proct中选出所有的pname来,一共有三条记录。
MySQL中的分页非常简单,我们可以使用limit
比如:
mysql
-------
|pname|
-------
|产品1|
|产品2|
-------
2rowsinset(000sec)
Limit用法如下:
第一个参数是指要开始的地方,第二个参数是指每页显示多少条数据;注意:第一页用0表示。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)