zoukankan      html  css  js  c++  java
  • 分页存储过程

    在圈子里的找了一个分页存储过程,

    set ANSI_NULLS ON
    set QUOTED_IDENTIFIER ON
    go
    
    CREATE PROCEDURE [dbo].[Proc_Page]
    (
         @TableName varchar(50),            --表名或视图
         @ReFieldsStr varchar(200) = '*',   --字段名(全部字段为*)
         @OrderFiled varchar(200),         --排序字段(必须!支持多字段不用加order by)
         @OrderType int = 0,                -- 设置排序类型, 非0 值则降序
         @WhereString varchar(500) =N'',  --条件语句(不用加where)
         @PageSize int,                     --每页多少条记录
         @PageIndex int = 1 ,               --指定当前为第几页
         @TotalRecord int output            --返回总记录数
    )
    AS
     
    BEGIN    
    
        --处理开始点和结束点
        Declare @StartRecord int;
        Declare @EndRecord int; 
        Declare @TotalCountSql nvarchar(500); 
        Declare @SqlString nvarchar(2000);    
        set @StartRecord = (@PageIndex-1)*@PageSize + 1
        set @EndRecord = @StartRecord + @PageSize - 1 
        SET @TotalCountSql= N'select @TotalRecord = count(*) from [' + @TableName+']';--总记录数语句
        IF @OrderType!=0 --降序
        BEGIN 
        SET @SqlString = N'(select row_number() over (order by '+ @OrderFiled +' desc) as rowId,'+@ReFieldsStr+' from ['+ @TableName+']';--查询语句
        END 
        ELSE 
        BEGIN 
        SET @SqlString = N'(select row_number() over (order by '+ @OrderFiled +' asc) as rowId,'+@ReFieldsStr+' from ['+ @TableName+']';--查询语句
        END 
        --
        IF (@WhereString! = '' or @WhereString!=null)
            BEGIN
                SET @TotalCountSql=@TotalCountSql + '  where '+ @WhereString;
                SET @SqlString =@SqlString+ '  where '+ @WhereString;            
            END
        --第一次执行得到
        --IF(@TotalRecord is null)
        --   BEGIN
               EXEC sp_executesql @totalCountSql,N'@TotalRecord int out',@TotalRecord output;--返回总记录数
        --  END
        ----执行主语句
        set @SqlString ='select * from ' + @SqlString + ') as t where rowId between ' + ltrim(str(@StartRecord)) + ' and ' +  ltrim(str(@EndRecord));
        Exec(@SqlString)    
    END
        
    
    EXEC dbo.Proc_Page
        @TableName = 'Afagouinfo', -- varchar(50)
        @ReFieldsStr = 'diqu,flag', -- varchar(200)
        @OrderFiled = 'id', -- varchar(200)
        @OrderType = 0, -- int
        @WhereString = '', -- varchar(500)
        @PageSize = 10, -- int
        @PageIndex = 1, -- int
        @TotalRecord = 20 -- int
  • 相关阅读:
    Android 内存剖析 – 发现潜在问题
    Android内存泄漏问题(一)
    Android的事件处理机制详解(二)-----基于监听的事件处理机制
    Android的事件处理机制(一)------基于回调机制的事件处理
    OOA、OOD 和 OOP
    面向对象初识
    Python 2 和 Python 3 的区别
    软件开发规范
    语法分析和词法分析
    循环删除的坑
  • 原文地址:https://www.cnblogs.com/for917157ever/p/2548120.html
Copyright © 2011-2022 走看看