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


    CREATE PROC GetRecordFromPage
        @tableName      varchar(255),       -- 表名
        @fieldName      varchar(255),       -- 字段名
        @PageSize     int = 10,           -- 每页显示多少条
        @PageIndex    int = 1,            -- 第几页
        @OrderType    bit = 0,            -- 设置排序类型, 非0 值则降序
        @IsCount bit = 0, -- 为0返回记录总数, 非0 值则返回数据集
        @strWhere     varchar(2000) = ''  -- 查询条件 不要where
    AS
    declare @strSQL   varchar(5000)       -- 主语句(变量)
    declare @strTemp   varchar(1000)       -- 临时条件(变量)
    declare @strOrder varchar(500)        -- 排序字段
    if @OrderType != 0
    begin
        set @strTemp = '<(select min'
        set @strOrder = ' order by [' + @fieldName + '] desc'
    end
    else
    begin
        set @strTemp = '>(select max'
        set @strOrder = ' order by [' + @fieldName +'] asc'
    end
    set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
        + @tableName + '] where [' + @fieldName + ']' + @strTemp + '(['
        + @fieldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
        + @fieldName + '] from [' + @tableName + ']' + @strOrder + ') as tblTmp)'
        + @strOrder
    if @strWhere != ''
        set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
            + @tableName + '] where [' + @fieldName + ']' + @strTemp + '(['
            + @fieldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
            + @fieldName + '] from [' + @tableName + '] where ' + @strWhere + ' '
            + @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
    if @PageIndex = 1
    begin
        set @strTemp = ''
        if @strWhere != ''
            set @strTemp = ' where (' + @strWhere + ')'
        set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
            + @tableName + ']' + @strTemp + ' ' + @strOrder
    end
    if @IsCount != 0
    set @strSQL = 'select count(' + @fieldName + ') as Total from [' + @tableName + ']'
    exec (@strSQL)


  • 相关阅读:
    一个提高查找速度的小技巧
    COM是一个更好的C++
    15道简单算法题
    非递归实现文件夹遍历
    《STL系列》之map原理及实现
    《STL系列》之vector原理及实现
    MVC5 IIS7 403错误
    Vue在线客服系统【开源项目】
    Xcode No account for team "". Add a new account in the Accounts preference pane or verify that your accounts have valid credentials.
    CSS flex布局
  • 原文地址:https://www.cnblogs.com/manage/p/1929455.html
Copyright © 2011-2022 走看看