zoukankan      html  css  js  c++  java
  • 数据库分页存储过程(5)

    /*
    ******************************************************************************************
      过程名称:Common_Percent_Pagination
      过程功能:
      代码设计:小朱(zsy619@163.com)
      设计时间:2005-11-3 13:58:26
    ******************************************************************************************
      功能描述:

    ******************************************************************************************
      如果您修改了我的程序,请留下修改记录,以便对程序进行维护,谢谢  !!!
    ==========================================================================================
      修改人            修改时间                修改原因
    ------------------------------------------------------------------------------------------

    ==========================================================================================

    ******************************************************************************************
      备注:
    *****************************************************************************************
    */

    Create Procedure [dbo].[Common_Percent_Pagination]
        
    @TBName NVARCHAR(255) ,
        
    @SQL nVARCHAR(4000),    --不带排序语句的SQL语句
        @Page int,              --页码
        @RecsPerPage int,       --每页容纳的记录数
        @ID VARCHAR(255),       --需要排序的不重复的ID号
        @Sort VARCHAR(255) ,     --排序字段及规则
        @PageCount INT OUTPUT          --总页数
    AS
        
    Declare @intResult Int
        
    Begin Tran
        
    -----------------------------------------------------------------代码设计--------------------------------------------------------------------
        DECLARE @sql1 nvarchar(4000)
        
    SET @sql1=N'SELECT @PageCount=COUNT(*)'
            
    +N' FROM '+@tbname  
        
    EXEC sp_executesql @sql1,N'@PageCount int OUTPUT',@PageCount OUTPUT
        
    SET @PageCount=(@PageCount+@RecsPerPage-1)/@RecsPerPage
        
    DECLARE @Str nVARCHAR(4000
        
    SET @Str='SELECT   TOP '+CAST(@RecsPerPage AS VARCHAR(20))+' * FROM ('+@SQL+') T WHERE T.'+@ID+' NOT IN (SELECT   TOP '+CAST((@RecsPerPage*(@Page-1)) AS VARCHAR(20))+' '+@ID+' FROM ('+@SQL+') T9 ORDER BY '+@Sort+') ORDER BY '+@Sort 
        
    --PRINT @Str 
        --EXEC sp_ExecuteSql @Str
        --EXEC @Str
        DECLARE @Str1 NVARCHAR(400)
        
    DECLARE @Str2 NVARCHAR(400)
        
    SET @Str1 = CAST(@RecsPerPage AS VARCHAR(20))
        
    SET @Str2 = CAST((@RecsPerPage*(@Page-1)) AS VARCHAR(20))
        
    EXEC ( N'SELECT   TOP '+@Str1+ N' * FROM ('+@SQL+N') T WHERE T.'+@ID+N' NOT IN (SELECT   TOP '+@Str2+N' '+@ID+N' FROM ('+@SQL+N') T9 ORDER BY '+@Sort+N') ORDER BY '+@Sort )
        
    Set @intResult = @@ROWCOUNT
        
    ----------------------------------------------------------------------------------------------------------------------------------------------------
        If @@Error <> 0
        
    Begin
            
    RollBack Tran
            
    Return -1
        
    End
        
    Else
        
    Begin
            
    Commit Tran
            
    Return @intResult
        
    End
    GO
  • 相关阅读:
    React之改变页面上方图标
    箭头函数参数解构
    h5项目(特别是vue)缓存严重的解决方案,配合nginx
    springboot中配置urlrewrite实现url伪静态强化网站seo
    使用docker创建mongodb
    mac下sourcetree创建git分支和合并分支
    在系统下文件上传报错:The temporary upload location [/tmp/tomcat.xxx/work/Tomcat/localhost/ROOT] is not valid
    解决Mac下SourceTree每次都让输入密码的问题
    快速生成mysql上百万条测试数据
    10年前错过比特币,如今有斯坦福区块链项目pi币,对标btc,手机免费挖矿详细教程。
  • 原文地址:https://www.cnblogs.com/zsy/p/311238.html
Copyright © 2011-2022 走看看