asp.net下经典数据库记录分页代码
asp.net下经典数据库记录分页代码
发布时间:2016-12-29 来源:查字典编辑
摘要:1、SELECTTOPPAGESIZENEWSTITLEFORMNEWSINFOWHERENEWSIDNOTIN(SELECTTOP(PAG...

1、

SELECTTOPPAGESIZENEWSTITLE

FORMNEWSINFOWHERENEWSIDNOTIN

(SELECTTOP(PAGE-1)*PAGESIZENEWSIDFROMNEWSINFO

WHEREAuditing=1andNEWSBREED='企业新闻'orderbyNEWSIDDESC)

ANDAuditing=1andNEWSBREED='企业新闻'orderbyNEWSIDDESC

其中:PAGE表示当前页数,PAGESIZE表示页的大小;这里利用了NOTIN,不复合SARG,但总比一次读取全部的记录要好的多。

2、符合SARG的代码

针对本人的实例还有一个更好的方案:因为NEWSID字段是自增字段,对于NOTIN语句进行如下的改造,并不影响结果。但速度提高了很多

SELECTTOPPAGESIZENEWSTITLE

FORMNEWSINFOWHERENEWSID<

(SELECTMIN(NEWSID)FROM(SELECTTOP(PAGE-1)*PAGESIZENEWSIDFROMNEWSINFOWHEREAuditing=1andNEWSBREED='企业新闻'orderbyNEWSIDDESC)ASTB)ANDAuditing=1andNEWSBREED='企业新闻'orderbyNEWSIDDESC

【说明】

对于在多处使用分页功能的web应用程序,把SQL语句改为存储过程将会更好。

请大家积极参与讨论分页的算法,并把好的方案与大家分享。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新asp.net教程学习
热门asp.net教程学习
编程开发子分类