• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    sql 存储过程分页
    POST TIME:2021-10-18 07:20
    CREATE PROC myx_prPageRecordset
    @queryStr nvarchar(1000), 
    @keyField nvarchar (200), 
    @pageSize int, 
    @pageNumber int 
    AS
    BEGIN
    DECLARE @sqlText AS nvarchar(4000)
    DECLARE @sqlTable AS nvarchar(4000)
    SET @sqlTable = 'SELECT TOP ' + CAST((@pageNumber + 1) * @pageSize AS varchar(30)) + ' ' + @queryStr
    SET @sqlText =
    'SELECT TOP ' + CAST(@pageSize AS varchar(30)) + ' * ' + 
    'FROM (' + @sqlTable + ') AS tableA ' +
    'WHERE ' + @keyField + ' NOT IN(SELECT TOP ' +
    CAST(@pageNumber * @pageSize AS varchar(30)) + ' ' + @keyField + 
    ' FROM (' + @sqlTable + ') AS tableB)'
    EXEC (@sqlText)
    END

    GO

    核心代码
    Dim strsql As String
    myComm = New SqlClient.SqlCommand("myx_prPageRecordset", myConn)
    myComm.CommandType = CommandType.StoredProcedure
    myComm.Parameters.Add(New SqlClient.SqlParameter("@queryStr", SqlDbType.NVarChar, 1000))
    myComm.Parameters("@queryStr").Value = " * from tbpage order by id DESC"
    myComm.Parameters.Add(New SqlClient.SqlParameter("@keyField", SqlDbType.NVarChar, 200))
    myComm.Parameters("@keyField").Value = "[id]"
    myComm.Parameters.Add(New SqlClient.SqlParameter("@pageSize", SqlDbType.NVarChar, 1000))
    myComm.Parameters("@pageSize").Value = PageSize
    myComm.Parameters.Add(New SqlClient.SqlParameter("@pageNumber", SqlDbType.NVarChar, 1000))
    myComm.Parameters("@pageNumber").Value = myPage - 1

    呵呵,执行几W条的代码只需150毫秒左右

    建立一个test(id,name,fid)
    向test添充几十条数据,使id=1,2,3,4.........(即递增的integer),其他任意
    在T-sql Debugger给改存储过程分别传递如下参数:
    @queryStr= * from test
    @keyField=[ID] 
    @pageSize=3 
    @pageNumber=1
    问题出来了,看输出结果(注意id):
    id name fid
    4 kwklover 2
    5 kwklover 2
    6 kwklover 2
    根据传入参数,我们的预期应该是:
    id name fid
    1 kwklover 2
    2 kwklover 2
    3 kwklover 2

    下面是我参照小春的存储分页写的分页存储过程,可以解决上面的问题:
    CREATE Procedure prGetRecordByPage
    (
    @PageSize int, --每页的记录条数 
    @PageNumber int, --当前页面
    @QuerySql varchar(1000),--部分查询字符串,如* From Test order by id desc
    @KeyField varchar(500) 
    )
    AS
    Begin

    Declare @SqlTable AS varchar(1000)
    Declare @SqlText AS Varchar(1000)

    Set @SqlTable='Select Top '+CAST(@PageNumber*@PageSize AS varchar(30))+' '+@QuerySql
    Set @SqlText='Select Top '+Cast(@PageSize AS varchar(30))+' * From '
    +'('+@SqlTable+') As TembTbA '
    +'Where '+@KeyField+' Not In (Select Top '+CAST((@PageNumber-1)*@PageSize AS varchar(30))+' '+@KeyField+' From '
    +'('+@SqlTable+') AS TempTbB)'
    Exec(@SqlText)

    End
    GO 
    您可能感兴趣的文章:
    • SQL通用存储过程分页,支持多表联合
    • sql 存储过程分页代码 支持亿万庞大数据量
    • sql2005 存储过程分页代码
    • sqlserver 存储过程分页(按多条件排序)
    • sql2005 存储过程分页示例代码
    • MsSql 存储过程分页代码 [收集多篇]
    • asp.net SQL存储过程分页
    • asp 存储过程分页代码
    • 存储过程实现(可带查询条件/万能分页/通用)
    上一篇:SQL Server 存储过程的分页
    下一篇:邹建的分页存储过程改了一下
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信