DataGrid连接Access的快速分页法(3)——SQL语句的选用(降序)

王朝c#·作者佚名  2006-01-08
宽屏版  字体: |||超大  

DataGrid连接Access的快速分页法(3)——SQL语句的选用(降序)

三、降序

(1)@PageIndex <= @FirstIndex

SELECT TOP @PageSize @QueryFields

FROM @TableName

WHERE @Condition

ORDER BY @PrimaryKey DESC

(2)@FirstIndex < @PageIndex <= @MiddleIndex

SELECT TOP @PageSize @QueryFields

FROM @TableName

WHERE @PrimaryKey < (

SELECT MIN(@PrimaryKey) FROM (

SELECT TOP @PageSize*@PageIndex @PrimaryKey

FROM @TableName

WHERE @Condition

ORDER BY @PrimaryKey DESC

) TableA

) WHERE @Condition

ORDER BY @PrimaryKey DESC

(3)@MiddleIndex < @PageIndex < @LastIndex

SELECT * FROM (

SELECT TOP @PageSize @QueryFields

FROM @TableName

WHERE @PrimaryKey > (

SELECT MAX(@PrimaryKey) FROM (

SELECT TOP (@RecordCount-@PageSize*(@PageIndex+1)) @PrimaryKey

FROM @TableName

WHERE @Condition

-- ORDER BY @PrimaryKey ASC

) TableA

) WHERE @Condition

-- ORDER BY @PrimaryKey ASC

) TableB

ORDER BY @PrimaryKey DESC

(4)@PageIndex >= @LastIndex

SELECT * FROM (

SELECT TOP (@RecordCount-@PageSize*@LastIndex) @QueryFields

FROM @TableName

WHERE @Condition

ORDER BY @PrimaryKey ASC

) TableA

ORDER BY @PrimaryKey DESC

四、总结

通过上面的讨论,相信大家应该看到了该分页方法的优势所在。在下一篇中,我将给大家一个动态生成上面 SQL 语句的类。

作者:黎波

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有