主頁 > 知識庫 > SQL分頁查詢存儲過程代碼分享

SQL分頁查詢存儲過程代碼分享

熱門標簽:谷歌地圖標注位置圖解 沈陽智能外呼系統(tǒng)供應商 南通電銷外呼系統(tǒng)哪家強 東莞外呼企業(yè)管理系統(tǒng) 清遠申請400電話 手機外呼系統(tǒng)違法嗎 如何選擇優(yōu)質(zhì)的外呼系統(tǒng) 地圖簡圖標注 桂林云電銷機器人收費

話不多說,請看代碼

-------------------------------------
-----作者:張欣宇
-----時間:2013-06-28
-----簡介:根據(jù)參數(shù)和條件分頁查詢
-------------------------------------
Create proc [dbo].[Up_PagingQueryByParameter]
(
 ----- 表名或能查詢到結(jié)果的SQL語句{SQL語句左右必須有括號例:(select * from tbl1)}
 @TableName varchar(max),
 ----- 要查詢的列名語句; 可空默認*
 @ColumnName varchar(5000),
 ----- 用來排序的列; 不可為空
 @OrderByColumnName varchar(50),
 ----- 排序desc(倒序5.4.3.2.1)或asc(正序1.2.3.4.5); 可空默認asc
 @ShrtBy varchar(4),
 ----- Where條件; 可空默認1=1
 @Where varchar(5000),
 ----- 每頁顯示數(shù); 可空默認20
 @PageShows int,
 ----- 當前頁數(shù); 可空默認1
 @CurrentPage int,
 ----- 0為分頁查詢;其他為查詢?nèi)? 可空默認0
 @IsPaging int
)
as
begin
 ----- 參數(shù)檢查及規(guī)范
 if isnull(@Where,N'')=N'' set @Where = N'1=1';
 if isnull(@ColumnName,N'')=N'' set @ColumnName = N'*';
 if isnull(@PageShows,0)1 set @PageShows = 20;
 if isnull(@CurrentPage,0)1 set @CurrentPage = 1;
 if isnull(@ShrtBy,N'')=N'' set @ShrtBy = 'asc';
 if isnull(@IsPaging,0)>1 set @IsPaging = 0;
 ----- 定義
 -- 拼接的SQL語句
 declare @SqlStr nvarchar(max);
 declare @SqlWithStr nvarchar(max);
 -- 開始條數(shù)
 declare @StartIndex int;
 -- 結(jié)束條數(shù)
 declare @EndIndex int;
 ----- 賦值
 set @StartIndex = (@CurrentPage-1)*@PageShows+1;
 print(@CurrentPage);
 print(@PageShows);
 print(@StartIndex);
 set @EndIndex = @CurrentPage*@PageShows;
 print(@EndIndex);
 set @OrderByColumnName=@OrderByColumnName+' '+@ShrtBy;
 ----- 分頁查詢
 set @SqlWithStr = N'with temp as(select ROW_NUMBER() over(order by '+@OrderByColumnName+N') as RowNumber,'+@ColumnName+N' from '+@TableName+N' as tableName where '+@Where+N')';
 if(@IsPaging = 0)
 begin
 set @SqlStr = @SqlWithStr + N' select '+@ColumnName+N' from temp where temp.RowNumber between '+convert(nvarchar(20),@StartIndex)+N' and '+convert(nvarchar(20),@EndIndex)+N'';
 ---- print(@SqlStr);
 exec(@SqlStr);
 ----- 總數(shù)查詢
 set @SqlStr = @SqlWithStr + N' select count(*) as TotalNumber from temp';
 ---- print(@SqlStr);
 exec(@SqlStr);
 end
 else
 begin
 set @SqlStr = @SqlWithStr + N' select '+@ColumnName+N' from temp';
 ---- print(@SqlStr);
 exec(@SqlStr);
 end
end

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

您可能感興趣的文章:
  • 五種SQL Server分頁存儲過程的方法及性能比較
  • SQL Server 分頁查詢通用存儲過程(只做分頁查詢用)
  • sqlserver2005利用臨時表和@@RowCount提高分頁查詢存儲過程性能示例分享
  • 深入sql server 2005 萬能分頁存儲過程的詳解
  • 基于Sql Server通用分頁存儲過程的解決方法
  • mssql 高效的分頁存儲過程分享
  • SQL Server 2005通用分頁存儲過程及多表聯(lián)接應用
  • MSSQL MySQL 數(shù)據(jù)庫分頁(存儲過程)
  • 三種SQL分頁查詢的存儲過程代碼
  • SQL通用存儲過程分頁,支持多表聯(lián)合

標簽:常德 內(nèi)蒙古 臨沂 貴州 重慶 成都 天津 湖州

巨人網(wǎng)絡通訊聲明:本文標題《SQL分頁查詢存儲過程代碼分享》,本文關(guān)鍵詞  SQL,分頁,查詢,存儲,過程,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL分頁查詢存儲過程代碼分享》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL分頁查詢存儲過程代碼分享的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章