zoukankan      html  css  js  c++  java
  • ASP.NET中的分页SQL语句[利用SQL2005的Row_Number()函数]

          最近给客户做了个查看通话记录的小功能,不论是查询还是显示都很快的完成了。唯一的问题就是因为数据记录太多[上万条,且每天都已几十近百条的速度增长],显示速度太慢。我用的是VS2005 GridView自带的分页功能,显然数据太多GridView自身的分页功能已经不在适用。本来想用存储过程,但感觉太麻烦。在网上淘了半天,终于淘了个非常好的利用SQLServer2005自带的Row_Number()函数做的SQL语句分页的方法。闲话少说,看代码:
     1declare @pageIndex int
     2declare @pageSize  int
     3set @pageIndex=1
     4set @pageSize=26
     5
     6SELECT * FROM (SELECT ROW_NUMBER() OVER(ORDER BY id DESCAS rownum,
     7id, callerno, calleeno, uid, callbegin,callend,bs
     8FROM [222.43.48.95].lyzj.dbo.billlog where uid='007'AS D
     9WHERE rownum BETWEEN (@pageIndex-1)*@pageSize+1 AND @pageIndex*@pageSize
    10ORDER BY id DESC
            上面就是分页的SQL语句,但是实际使用的时候,问题又出现了。我用的是ASPNETPager分页控件,查看的时候,第一页的数据总是无法显示;调试了半天才找出原因。原来是早先用GridView自身的分页时,分页的索引是从0开始的,而现在的分页却是从1 开始。两者搅在一起,不出问题都怪了,呵呵,搞定!
    QQ:413708116 仅作技术交流
  • 相关阅读:
    数字雨-贪吃蛇
    C语言入门9-2-模块大致一览
    C语言入门9-1-分类函数
    C语言入门8-数组-基本算法
    C语言入门7-程序设计方法基础-循环结构
    C语言入门6-选择结构--f语句-switch
    C语言入门5-键盘的输入和屏幕输出
    C语言入门4-运算符和表达式
    C语言入门3-C语言概述及数据类型
    Systemd 入门教程:命令篇
  • 原文地址:https://www.cnblogs.com/ywcz060/p/1573031.html
Copyright © 2011-2022 走看看