目录

文章目录

  • 说明
  • 语法
  • 1.mysql语法
  • - 指定初始位置
  • - 不指定初始位置
  • - 配合offset使用
  • 2.sql server语法
  • - 三重循环
  • - 利用max(主键)
  • - 利用row_number关键字(2005版本以上才有)
  • - offset /fetch next(2012版本及以上才有)
  • 3.orcale语法
  • - 采用伪列 rownum
  • - 分页查询一
  • - 分页查询二
  • - 分页查询三
  • 参考链接


说明

分页查询是为了让我们准确查询到某部分的数据,跟我们在网页的下一页那类是可以同等理解的,一页查询多少条数据,从数据的第几行开始显示,都是这个分页查询可以实现的。

语法

1.mysql语法

说明:limit是mysql中的分页语法,但也是限制查询结果的条数注意:limit后的数必须是整数!

- 指定初始位置

select 字段名 from 数据表名  limit 初始位置,记录条数

初始位置从0开始

- 不指定初始位置

limit 记录数

“记录数”表示显示记录的条数。如果“记录数”的值小于查询结果的总数,则会从第一条记录开始,显示指定条数的记录。如果“记录数”的值大于查询结果的总数,则会直接显示查询出来的所有记录。

- 配合offset使用

limit 记录数 offset 初始位置

2.sql server语法

原作者中带有查看性能的代码,所以有兴趣可以去看文尾的链接。

-- 设置执行时间开始,用来查看性能的
set statistics time on ;

- 三重循环

1.先取前20页,然后倒序,取倒序后前10条记录,这样就能得到分页所需要的数据,不过顺序反了,之后可以将再倒序回来,也可以不再排序了,直接交给前端排序。

-- 分页查询(top)
select * 
from (select top pageSize * 
from (select top (pageIndex*pageSize) * 
from 数据表 
order by 字段id asc ) -- 其中里面这层,必须指定按照升序排序,省略的话,查询出的结果是错误的。
as temp_sum_student -- 另命名
order by 字段id desc ) temp_order
order by 字段id asc

-- 分页查询第2页,每页有10条记录
select * 
from (select top 10 * 
from (select top 20 * 
from 数据表 
order by sNo asc ) -- 其中里面这层,必须指定按照升序排序,省略的话,查询出的结果是错误的。
as temp_sum_student 
order by 字段id desc ) temp_order
order by 字段id asc
;

2.先查询出前10条记录,然后用not in排除了这10条,再查询。无代码。

- 利用max(主键)

先top前11条行记录,然后利用max(id)得到最大的id,之后再重新再这个表查询前10条,不过要加上条件,where id>max(id)。

-- 分页查询(max)
select top pageSize * 
from 数据表 
where 字段id>=
(select max(字段id) 
from (select top ((pageIndex-1)*pageSize+1) 字段id
from 数据表 
order by  字段id asc) temp_max_ids) 
order by 字段id;
-- 分页查询第2页,每页有10条记录
select top 10 * 
from 数据表 
where 字段id>=
(select max(字段id) 
from (select top 11 字段id
from 数据表 
order by 字段id asc) temp_max_ids) 
order by 字段id;

- 利用row_number关键字(2005版本以上才有)

直接利用row_number() over(order by id)函数计算出行数,选定相应行数返回即可

-- 分页查询(row_number)
select top pageSize * 
from (select row_number() 
over(order by 字段id asc) as rownumber,* 
from 数据表 ) temp_row
where rownumber>((pageIndex-1)*pageSize);

-- 分页查询第2页,每页有10条记录
select top 10 * 
from (select row_number() 
over(order by 字段id asc) as rownumber,* 
from 数据表 ) temp_row
where rownumber>10;

- offset /fetch next(2012版本及以上才有)

offset A rows ,将前A条记录舍去,fetch next B rows only ,向后在读取B条数据。

-- 分页查询(offset /fetch next)
select * from 数据表
order by 字段id 
offset ((@pageIndex-1)*@pageSize) rows
fetch next @pageSize rows only;

-- 分页查询第2页,每页有10条记录
select * from 数据表
order by 字段id  
offset 10 rows
fetch next 10 rows only ;

说明:原作者推荐最后一种,第一种性能很差,本人没有实操,无法判定,故照搬。

3.orcale语法

- 采用伪列 rownum

1.查询前10条记录

select * from 数据表 where ROWNUM <10;

2.按照ID排名,抓取前三条记录 不能对ROWNUM使用>(大于1的数值)、>=(大于或等于1的数值)、=(大于或等于1的数值),否则无结果,所以直接用只能从1开始 rownum >10 没有记录,因为第一条不满足去掉的话,第二条的rownum又成了1,所以永远没有满足条件的记录。

select * from 数据表 where rownum>=1;

3.如果想要用rownum不从1开始,需按下面方法使用

select 表别名.* 
from (select 数据表.*,rownum rn from 数据表) 表别名 
where rn >5;

- 分页查询一

select * from (
select 表别名.*,rownum rn from (
select * from 数据表) 表别名
where rownum <=5) 
where rn>=2;

- 分页查询二

select 表别名.* from (
select 数据表.*,rownum rn 
from 数据表 
where rownum <=5) 表别名 
where rn >=3;

- 分页查询三

select 表别名.* from (
select 数据表.*,rownum rn 
from 数据表) 表别名 
where rn between 3 and 5;

因为我没有学过oracle,所以都是其他部分截取,请多参考其他的。

参考链接

1.MySQL LIMIT:限制查询结果的条数 2.数据库分页查询 3.SQL server分页的四种方法(算很全面了) 4.Oracle数据库分页的三种方法