使用SQL Server 2005的T-SQL在服务器端进行分页是用到的SQL语句。
1、
select *
from ssp_soi
where ssp_soi_id in (
select ssp_soi_id
from (
select ssp_soi_id,
ROW_NUMBER() OVER(ORDER BY ssp_soi_id) as nid
from ssp_soi
) as tid
where nid between 21 and 50
)
2、
SELECT *
FROM (
select *,ROW_NUMBER() Over(order by ssp_soi_id) as rowNum
from ssp_soi )
as myTable
where rowNum between 21 and 50
3、
WITH OrderedOrders AS
(SELECT *,
ROW_NUMBER() OVER (order by ssp_soi_id)as RowNumber
FROM ssp_soi )
SELECT *
FROM OrderedOrders
WHERE RowNumber between 21 and 50
而在ORACLE中的分页语句也类似
1、
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM s_command) A
WHERE ROWNUM <= 10
)
WHERE RN >= 1
2、
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM s_command) A
)
WHERE RN BETWEEN 1 AND 10
而按效率来考虑,上述的第一种方法的效率要比第二种高很多。
这是由于CBO优化模式下,Oracle可以将外层的查询条件推
到内层查询中,以提高内层查询的执行效率。对于第一个查询语句,第二层的查询条件WHERE ROWNUM <=
40就可以被Oracle推入到内层查询中,这样Oracle查询的结果一旦超过了ROWNUM限制条件,就终止查询将结果返回了。
而第二个查询语句,由于查询条件BETWEEN 21 AND
40是存在于查询的第三层,而Oracle无法将第三层的查询条件推到最内层(即使推到最内层也没有意义,因为最内层查询不知道RN代表什么)。因此,对
于第二个查询语句,Oracle最内层返回给中间层的是所有满足条件的数据,而中间层返回给最外层的也是所有数据。数据的过滤在最外层完成,显然这个效率
要比第一个查询低得多。
同时,Oracle也支持ROW_NUMBER() OVER (partition by 字段 order by 字段
),如下:
WITH TMS_e_user AS (
SELECT ROW_NUMBER() over (ORDER BY euse_id) ROWNO, e_user.* FROM e_user WHERE 1=1)
SELECT * FROM TMS_e_user WHERE ROWNO BETWEEN 1 AND 5
MySQL则比较简单
1、
SELECT * FROM bus_register LIMIT 1, 5
分享到:
相关推荐
SQL Server 2005 分页查询常用方法
sql Server 通用分页存储过程 sql Server 通用分页存储过程 sql Server 通用分页存储过程 sql Server 通用分页存储过程
一个非常好的sql2005分页函数,简单实用,希望对你有所帮助
mybatis中,sqlserver分页
SQL server2008中通用分页存储过程,表名,每页长度,页码都是动态赋值。
关于SQL Server SQL语句查询分页数据的解决方案
通用的Sql Server分页程序,并且符合BootStrap Table 的调用标准.
SQLServer数据库分页,提供SQLServer内部分页
sqlserver分页查询语句;sqlserver分页查询语句;sqlserver分页查询语句;
sqlserver分页sql
不错的分页(Hibernate+sqlserver2000分页)值得大家一看。
java 连接sqlserver数据库查询,并分页显示
sql server2005 分页查询语句
sql server分页技术 详解 sql server分页技术 详解 sql server分页技术 详解
ASP.NET基于SQLServer的分页
asp+sqlserver2005万能分页存储过程源码 sqlserver2005源码下载,很灵活的
SQL Server 2005微软官方权威参考书. 公球公认SQL Server 2005 经典著作.. 数据库“铁人”、微软MVP胡百敬先生鼎力推荐 微软SQL Server 总部Principal Group 项目经理朱凌志鼎力推荐 本书详细介绍了数据...
分页就是按照某种规则显示分组数据集,但是在SQL Server 中,分页并不是十分容易就能够实现。随着SQL Server的发布,其中的一些排序函数使得开发人员编写数据分页程序变得更加简单和高效。这些新的排序函数提供了...
sqlserver+group by分组查询分页存储过程
Sql Server BootStrap Table 分页 通用的Sql Server分页程序,并且符合BootStrap Table 的调用标准.