Mysql 分页语句Limit用法

转载自:http://qimo601.iteye.com/blog/1634748

1、Mysql的limit用法

在我们使用查询语句的时候,经常要返回前几条或者中间某几行数据,这个时候怎么办呢?不用担心,mysql已经为我们提供了这样一个功能。

Sql代码  

  1. SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset

LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。

Sql代码  

  1. mysql> SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15
  2. //为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1:
  3. mysql> SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last.
  4. //如果只给定一个参数,它表示返回最大的记录行数目:
  5. mysql> SELECT * FROM table LIMIT 5; //检索前 5 个记录行
  6. //换句话说,LIMIT n 等价于 LIMIT 0,n。

引用,路人乙:Mysql中limit的用法详解

2、Mysql的分页查询语句的性能分析

      MySql分页sql语句,如果和MSSQL的TOP语法相比,那么MySQL的LIMIT语法要显得优雅了许多。使用它来分页是再自然不过的事情了。

2.1最基本的分页方式:

Sql代码  

  1. SELECT ... FROM ... WHERE ... ORDER BY ... LIMIT ...

在中小数据量的情况下,这样的SQL足够用了,唯一需要注意的问题就是确保使用了索引:

举例来说,如果实际SQL类似下面语句,那么在category_id, id两列上建立复合索引比较好:

Sql代码  

  1. SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 50, 10

2.2子查询的分页方式:

随着数据量的增加,页数会越来越多,查看后几页的SQL就可能类似:

Sql代码  

  1. SELECT * FROM articles WHERE category_id = 123 ORDER BY id LIMIT 10000, 10

一言以蔽之,就是越往后分页,LIMIT语句的偏移量就会越大,速度也会明显变慢。

此时,我们可以通过子查询的方式来提高分页效率,大致如下:

Sql代码  

  1. SELECT * FROM articles WHERE  id >=
  2. (SELECT id FROM articles  WHERE category_id = 123 ORDER BY id LIMIT 10000, 1) LIMIT 10

2.3JOIN分页方式

Sql代码  

  1. SELECT * FROM `content` AS t1
  2. JOIN (SELECT id FROM `content` ORDER BY id desc LIMIT ".($page-1)*$pagesize.", 1) AS t2
  3. WHERE t1.id <= t2.id ORDER BY t1.id desc LIMIT $pagesize;

经过我的测试,join分页和子查询分页的效率基本在一个等级上,消耗的时间也基本一致。

explain SQL语句:

id select_type table type possible_keys key key_len ref rows Extra

1 PRIMARY <derived2> system NULL NULL NULL NULL 1

1 PRIMARY t1 range PRIMARY PRIMARY 4 NULL 6264 Using where

2 DERIVED content index NULL PRIMARY 4 NULL 27085 Using index

----------------------------------------

为什么会这样呢?因为子查询是在索引上完成的,而普通的查询时在数据文件上完成的,通常来说,索引文件要比数据文件小得多,所以操作起来也会更有效率。

实际可以利用类似策略模式的方式去处理分页,比如判断如果是一百页以内,就使用最基本的分页方式,大于一百页,则使用子查询的分页方式。

【引用原文,energy1010的空间:MySql分页sql语句

3、Oracle分页查询语句

Oralce数据库

从数据库表中第M条记录开始检索N条记录

Sql代码  

  1. SELECT * FROM (SELECT ROWNUM r,t1.* From 表名称 t1 where rownum < M + N) t2
  2. where t2.r >= M

例如从表Sys_option(主键为sys_id)中从第10条记录开始检索20条记录,语句如下:

Sql代码  

  1. SELECT * FROM (SELECT ROWNUM R,t1.* From Sys_option where rownum < 30 ) t2
  2. Where t2.R >= 10

3、MSSQLSERVER分页查询语句

SQL Server主要利用 SELECT TOP语句分页,具体方案,请参考

-------------------------------------

分页方案一:(利用Not In和SELECT TOP分页)

语句形式:

Sql代码  

  1. SELECT TOP 10 *
  2. FROM TestTable
  3. WHERE (ID NOT IN
  4. (SELECT TOP 20 id
  5. FROM TestTable
  6. ORDER BY id))
  7. ORDER BY ID

Sql代码  

  1. SELECT TOP 页大小 *
  2. FROM TestTable
  3. WHERE (ID NOT IN
  4. (SELECT TOP 页大小*页数 id
  5. FROM 表
  6. ORDER BY id))
  7. ORDER BY ID
  8. SELECT TOP 页大小 *

Sql代码  

  1. FROM TestTable
  2. WHERE (ID >
  3. (SELECT MAX(id)
  4. FROM (SELECT TOP 页大小*页数 id
  5. FROM 表
  6. ORDER BY id) AS T))
  7. ORDER BY ID

-------------------------------------

分页方案二:(利用ID大于多少和SELECT TOP分页)

语句形式:

Sql代码  

  1. SELECT TOP 10 *
  2. FROM TestTable
  3. WHERE (ID >
  4. (SELECT MAX(id)
  5. FROM (SELECT TOP 20 id
  6. FROM TestTable
  7. ORDER BY id) AS T))
  8. ORDER BY ID

-------------------------------------

分页方案三:(利用SQL的游标存储过程分页)

Sql代码  

  1. create procedure XiaoZhengGe
  2. @sqlstr nvarchar(4000), --查询字符串
  3. @currentpage int, --第N页
  4. @pagesize int --每页行数
  5. as
  6. set nocount on
  7. declare @P1 int, --P1是游标的id
  8. @rowcount int
  9. exec sp_cursoropen @P1 output,@sqlstr,@scrollopt=1,@ccopt=1,@[email protected] output
  10. select ceiling(1.0*@rowcount/@pagesize) as 总页数--,@rowcount as 总行数,@currentpage as 当前页
  11. set @currentpage=(@currentpage-1)*@pagesize+1
  12. exec sp_cursorfetch @P1,16,@currentpage,@pagesize
  13. exec sp_cursorclose @P1
  14. set nocount off

其它的方案:如果没有主键,可以用临时表,也可以用方案三做,但是效率会低。

建议优化的时候,加上主键和索引,查询效率会提高。

通过SQL 查询分析器,显示比较:我的结论是:

分页方案二:(利用ID大于多少和SELECT TOP分页)效率最高,需要拼接SQL语句

分页方案一:(利用Not In和SELECT TOP分页) 效率次之,需要拼接SQL语句

分页方案三:(利用SQL的游标存储过程分页) 效率最差,但是最为通用

在实际情况中,要具体分析。

时间: 2024-11-10 13:33:00

Mysql 分页语句Limit用法的相关文章

MySQL分页的LIMIT函数

SELECT * FROM 表名称 LIMIT M,N  .其中的m表示从第几条开始,0表示第一条:n表示一共显示几条. mysql_num_rows:取得结果行的数目. table中奇数行变色或偶数行变色:tr:nth_child(odd或even){里面写入颜色}:其中odd表示奇数行,even表示偶数行.MySQL分页的LIMIT函数,布布扣,bubuko.com

MySql 分页关键字(limit)

mysql分页关键字: limit m,n --m:表示从哪一行开始查,n:查询多少条 oracle分页关键字:: rownum SqlServer:top(2005以下版本)  row_number()(2005以后版本) 查询前10条数据: SELECT * FROM orderitems LIMIT 0,10 ##查询出前十条的数据从0开始 还可以这样写: SELECT * FROM orderitems LIMIT 10; ##查询出前十条数据 查询出第6条后面的5条数据: SELECT

mysql查询语句基本用法

一:mysql基本语句 1.显示可用数据库 show databases; 2.创建一个library数据库 create databaselibrary; 3.使用数据库 use library; 4.查看表 show tables; 5.建表语句 mysql> uselibrary; Database changed mysql> createtable viedos( -> video_id int(11) not nullauto_increment, -> title v

MYSQL 分页慢加速器 解决方案 MYSQL 分页优化 MYSQL 分页解决方案 LIMIT 优化

无论你是InnoD引擎LIMIT分页慢还是MyISAM引擎LIMIT分页慢,大伙SELECT查询分页一般都是这样的[数据总共2万条,需要查询3个字段]: SELECT `id` , `url` , `content` FROM `product` WHERE 1 ORDER BY `id` LIMIT 10000 , 100 执行速度是: 45.7秒 哈哈,慢的掉渣吧! 作者LET再次隆重推荐 MySql LIMIT 分页查询加速利器解决方案: http://my.oschina.net/car

mysql分页的limit优化

1.很多新人都会很纳闷,为什么我建了索引使用分页还是这么卡.好,现在让我们一步一步去找原因吧. 首先limit本身跟索引没有直接关系. 先建一张商品sku表 create table goods_sku( id int(10) unsigned not null auto_increment comment '自增ID', goods_id varchar(20) not null comment '商品id', sale_status tinyint comment '上下架状态(0下架,1上

mysql 分页查询 limit

每次都会忘掉limit,记录下来. 分页查询(limit 起始行,查询几行) -- 起始行从0开始 -- 分页:当前页  每页显示多少条 -- 分页查询当前页的数据的sql: SELECT * FROM student LIMIT (当前页-1)*每页显示多少条,每页显示多少条; -- 需求: 查询第1,2条记录(第1页的数据) SELECT * FROM student LIMIT 0,2; -- 查询第3,4条记录(第2页的数据) SELECT * FROM student LIMIT 2,

mysql 中的LIMIT用法

select * from table_name LIMIT 起始偏移量,数量 (1)起始偏移量为0:代表没有偏移,即从第1行开始. (2)数量为-1:代表是无穷,即偏移量之后所有的行. (3)LIMIT n <=> LIMIT 0,n 当起始偏移量较小时,用LIMIT性能较好. 当起始偏移量较大(大于1w)时,子查询较优. 1. select * from table_name LIMIT 10000,10; 2. select * from table_name where id>=

SpringMVC+Mybatis实现的Mysql分页数据查询

周末这天手痒,正好没事干,想着写一个分页的例子出来给大家分享一下. 这个案例分前端和后台两部分,前端使用面向对象的方式写的,里面用到了一些回调函数和事件代理,有兴趣的朋友可以研究一下.后台的实现技术是将分页Pager作为一个实体对象放到domain层,当前页.单页数据量.当前页开始数.当前页结束数.总数据条数.总页数都作为成员属性放到实体类里面. 以前项目数据库用的是oracle,sql语句的写法会从当前页开始数到当前页结束数查询数据.刚刚在这纠结了很长时间,查询到的数据显示数量总是有偏差,后来

MySQL的limit用法及优化(转)

常规用法: 用法一: SELECT `keyword_rank`.* FROM `keyword_rank` WHERE (advertiserid='59') LIMIT 2 OFFSET 1; 比如这个SQL ,limit后面跟的是2条数据,offset后面是从第1条开始读取. 用法二: SELECT `keyword_rank`.* FROM `keyword_rank` WHERE (advertiserid='59') LIMIT 2,1; 而这个SQL,limit后面是从第2条开始读