自己常用的分頁SQL

來源:互聯網
上載者:User
1.
   Select Top PageSize * From Table where biaoshi not in (Select Top (PageIndex-1)*PageSize biaoshi From Table )

2.
CREATE PROCEDURE [dbo].[UP_Common_Pager](
 @tblName   nvarchar(255),       -- 表名
 @Fields nvarchar(1000) = '*',  -- 需要返回的列
 @OrderField nvarchar(255)='',      -- 排序的欄位名
 @PageSize   int = 10,          -- 頁尺寸
 @PageIndex  int = 1,           -- 頁碼
 @doCount  bit = 0,   -- 返回記錄總數, 非 0 值則返回
 @OrderType bit = 1,  -- 設定排序類型, 非 0 值則降序
 @strWhere  nvarchar(1500) = '',  -- 查詢條件 (注意: 不要加 where)
 @sql nvarchar(4000)='' out
)AS
begin
 if @pageIndex=0
  set  @pageIndex=1
 declare @strSQL   nvarchar(4000)       -- 主語句
 declare @strTmp   nvarchar(110)        -- 臨時變數
 declare @strOrder nvarchar(400)        -- 排序類型
 if @doCount != 0
  begin
   if @strWhere !=''
    set @strSQL = 'select count(*) as Total from ' + @tblName + ' where ' + @strWhere
   else
    set @strSQL = 'select count(*) as Total from ' + @tblName + ''
  end 
 --以上代碼的意思是如果@doCount傳遞過來的不是0,就執行總數統計。以下的所有代碼都是@doCount為0的情況
 else
  begin
   if @OrderType != 0
    begin
     set @strTmp = '<(select min'
     set @strOrder = ' order by ' + @OrderField +' desc'
     --如果@OrderType不是0,就執行降序,這句很重要!
    end
   else
    begin
     set @strTmp = '>(select max'
     set @strOrder = ' order by ' + @OrderField +' asc'
    end
   if @PageIndex = 1
    begin
     if @strWhere != ''  
      set @strSQL = 'select top ' + str(@PageSize) +' '+@Fields+ '  from ' + @tblName + ' where ' + @strWhere + ' ' + @strOrder
     else
      set @strSQL = 'select top ' + str(@PageSize) +' '+@Fields+ '  from '+ @tblName + ' '+ @strOrder
    end
   else
    begin
     set @strSQL = 'select top ' + str(@PageSize) +' '+@Fields+ '  from '+ @tblName + ' where [' + @OrderField + ']' + @strTmp + '(['+ @OrderField + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['+ @OrderField + '] from ' + @tblName + '' + @strOrder + ') as tblTmp)'+ @strOrder
     if @strWhere != ''
      set @strSQL = 'select top ' + str(@PageSize) +' '+@Fields+ '  from '+ @tblName + ' where [' + @OrderField + ']' + @strTmp + '(['+ @OrderField + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['+ @OrderField + '] from ' + @tblName + ' where ' + @strWhere + ' '+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
    end
  end
 set @sql=@strSql
 exec (@strSQL)
end

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.