使用SQL Server 2005的T-SQL在服务器端进行分页是用到的SQL语句。
1、
1 select * 2 from ssp_soi 3 where ssp_soi_id in ( 4 select ssp_soi_id 5 from ( 6 select ssp_soi_id, 7 ROW_NUMBER() OVER ( ORDER BY ssp_soi_id) as nid 8 from ssp_soi 9 ) as tid 10 where nid between 21 and 50 11 )
2、
1 SELECT * 2 FROM ( 3 select * ,ROW_NUMBER() Over ( order by ssp_soi_id) as rowNum 4 from ssp_soi ) 5 as myTable 6 where rowNum between 21 and 50
3、
1 WITH OrderedOrders AS 2 ( SELECT * , 3 ROW_NUMBER() OVER ( order by ssp_soi_id) as RowNumber 4 FROM ssp_soi ) 5 SELECT * 6 FROM OrderedOrders 7 WHERE RowNumber between 21 and 50而在ORACLE中的分页语句也类似
1、
1 SELECT * FROM 2 ( 3 SELECT A. * , ROWNUM RN 4 FROM ( SELECT * FROM s_command) A 5 WHERE ROWNUM <= 10 6 ) 7 WHERE RN >= 1
2、
1 SELECT * FROM 2 ( 3 SELECT A. * , ROWNUM RN 4 FROM ( SELECT * FROM s_command) A 5 ) 6 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 字段 ),如下:
1 WITH TMS_e_user AS ( 2 SELECT ROW_NUMBER() over ( ORDER BY euse_id) ROWNO, e_user. * FROM e_user WHERE 1 = 1 ) 3 SELECT * FROM TMS_e_user WHERE ROWNO BETWEEN 1 AND 5
MySQL则比较简单
1、
1 SELECT * FROM bus_register LIMIT 1 , 5转载于:https://www.cnblogs.com/Jason_zhu/archive/2010/04/09/1708279.html
相关资源:sql server 2008通用分页