Heim  >  Artikel  >  Datenbank  >  MySql,Sqlserver,Oracle数据的分页语句

MySql,Sqlserver,Oracle数据的分页语句

WBOY
WBOYOriginal
2016-06-07 15:52:11933Durchsuche

在实际项目中分页是常见的不能再说了,这里我总结了MySql,SqlServer,Oracle这三个数据库的sql分页语句 在这三个数据库中,个人觉得MySql的分页语句是最简单的,只用一个limit关键字就能完成 MySql数据库: select * from test limit 5,5; test:表名 第一个

在实际项目中分页是常见的不能再说了,这里我总结了MySql,SqlServer,Oracle这三个数据库的sql分页语句

在这三个数据库中,个人觉得MySql的分页语句是最简单的,只用一个limit关键字就能完成

MySql数据库:

select  * from test limit 5,5;

test:表名

第一个参数5:从表中的第几行开始查,从0开始数

第二个参数5:查询出多少条记录

在项目中运用时,如果一个页面指定了显示多少条记录,通常第二个参数不会改变,都是该变的第一个参数

计算每页的公式:这里都是每页显示5条记录

第一页:(1-1)*5

第二页:(2-1)*5

第三页:(3-1)*5

第N页:(n-1)*5

公式:

开始的行数=(当前页-1)*每页显示的行数

所以最后在代码中的sql语句可以写为:

int pageSize=5;//每页显示行数

int pageNo=4;//当前页

int num=(pageNo-1)*pageSize;//开始查找的行

select * from test limit num,pageSize;

我了解的MySql数据的分页语句就只有这一种了


在SqlServer数据库中目前我了解的sql分页语句有两种

第一种:

select top(5) * from test 
	where id not in(
		select top((2-1)*5) id from test
	)

第二种:

select * from(
	select ROW_NUMBER() Over(order by id) as rownum,* from test
	) t 
where rownum between (2-1)*5+1 and 2*5


在Oracle数据库中我了解的一只有两种:

第一种:

select * from (
       select t.*,rownum rn from emp t 
       ) t1 
where rn>(2-1)*3 and rn
<p>也可以使用between</p>
<pre class="brush:php;toolbar:false">select * from (
       select t.*,rownum rn from emp t
       ) 
where rn between (2-1)*3+1 and 2*3

第二种:

select * from (
       select t.*,rownum rn from (
              select * from emp
       )t where rownum(2-1)*3

这两种比较起来,个人认为第一种查询相对比较快,因为第一种只查询了两次,而第二种查询的三次

至于怎样使用,看个人比较适合哪一种了






Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn