1、mssql
用两次 TOP 命令取得我们所要的分页数据,例如:
SELECT * FROM
(
SELECT TOP( PageSize ) * FROM
(
SELECT TOP ( PageSize * PageIndex ) *
FROM Articles
ORDER BY PubTime DESC
)
ORDER BY PubTime ASC
)
ORDER BY PubTime DESC
(
SELECT TOP( PageSize ) * FROM
(
SELECT TOP ( PageSize * PageIndex ) *
FROM Articles
ORDER BY PubTime DESC
)
ORDER BY PubTime ASC
)
ORDER BY PubTime DESC
2、oracle
对于 Oracle 数据库,有几处不同严重妨碍了上面几个方法的实施,比如,Oracle 不支持 TOP 关键字:不过这个好像并不十分严重,因为它提供了 rownum 这个隐式游标,可以实现与 TOP 类似的功能,如:
SELECT TOP 10 ... FROM WHERE ...
要写成
SELECT ... FROM ... WHERE ... AND rownum <= 10
rownum 是记录序号(1,2,3...),但有一个比较麻烦的事情是:如果 SQL 语句中有 ORDER BY ... 排序的时候,rownum 居然是先“标号”后排序!这样,这个序号如果不加处理是不合乎使用需求的。
可以如下分页:(编号 Ora1)
SELECT * FROM
(
SELECT A.*, rownum r
FROM
(
SELECT *
FROM Articles
ORDER BY PubTime DESC ,articleID --// 在排序时,加上一个或多个字段(如主键字段、 ROWID),使排序结果具有唯一性
) A
WHERE rownum <= PageUpperBound
) B
WHERE r > PageLowerBound;
(
SELECT A.*, rownum r
FROM
(
SELECT *
FROM Articles
ORDER BY PubTime DESC ,articleID --// 在排序时,加上一个或多个字段(如主键字段、 ROWID),使排序结果具有唯一性
) A
WHERE rownum <= PageUpperBound
) B
WHERE r > PageLowerBound;
其中蓝色部分可以改为任意的、需要的 SQL SELECT 语句,这点倒是挺方便的。
PS: Oracle 的 rownum 不支持 >,>=,=,between...and ,只能用以上符号 (< 、 <= 、 !=)