• 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)


  • 相关阅读:
    中专毕业后我的七年(励志篇,年轻人必看)
    Excel实战技巧之[二级条件级联]
    kingston DataTraveler2.0 4GU盘量产成功
    Windows XP SP3增强补丁 V1.3 破解uxtheme.dll和TCP/IP连接数的破解
    诺基亚系列手机型号命名研究
    硬件检测相关工具大全
    最好的MacOSX美化包——MacXize(支持SP3)
    我终于把《新概念英语》三册&四册全背下来了
    IBM T22故障
    Windows通用克隆系统入门基础知识简介
  • 原文地址:https://www.cnblogs.com/manage/p/1929455.html
Copyright © 2020-2023  润新知