溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

sqlserver通用分頁的存儲過程

發(fā)布時間:2021-08-30 19:17:13 來源:億速云 閱讀:141 作者:chen 欄目:數(shù)據(jù)庫

這篇文章主要講解了“sqlserver通用分頁的存儲過程”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“sqlserver通用分頁的存儲過程”吧!

復(fù)制代碼 代碼如下:

 create proc commonPagination @columns varchar(500), --要顯示的列名,用逗號隔開 @tableName varchar(100), --要查詢的表名 @orderColumnName varchar(100), --排序的列名 @order varchar(50), --排序的方式,升序為asc,降序為 desc @where varchar(100), --where 條件,如果不帶查詢條件,請用 1=1 @pageIndex int, --當(dāng)前頁索引 @pageSize int, --頁大小(每頁顯示的記錄條數(shù)) @pageCount int output --總頁數(shù),輸出參數(shù) as begin declare @sqlRecordCount nvarchar(1000) --得到總記錄條數(shù)的語句 declare @sqlSelect nvarchar(1000) --查詢語句 set @sqlRecordCount=N'select @recordCount=count(*) from ' +@tableName + ' where '+ @where declare @recordCount int --保存總記錄條數(shù)的變量 exec sp_executesql @sqlRecordCount,N'@recordCount int output',@recordCount output --動態(tài) sql 傳參 if( @recordCount % @pageSize = 0) --如果總記錄條數(shù)可以被頁大小整除 set @pageCount = @recordCount / @pageSize --總頁數(shù)就等于總記錄條數(shù)除以頁大小 else --如果總記錄條數(shù)不能被頁大小整除 set @pageCount = @recordCount / @pageSize + 1 --總頁數(shù)就等于總記錄條數(shù)除以頁大小加1 set @sqlSelect = N'select '+@columns+' from ( select row_number() over (order by ' +@orderColumnName+' '+@order +') as tempid,* from ' +@tableName+' where '+ @where +') as tempTableName where tempid between ' +str((@pageIndex - 1)*@pageSize + 1 ) +' and '+str( @pageIndex * @pageSize) exec (@sqlSelect) --執(zhí)行動態(tài)Sql end go --以下是調(diào)用示例 use pubs go declare @pageCount int exec commonPagination 'job_id,job_desc','jobs','job_id', 'asc','1=1',2,2,@pageCount output select '總頁數(shù)為:' + str(@pageCount)

感謝各位的閱讀,以上就是“sqlserver通用分頁的存儲過程”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對sqlserver通用分頁的存儲過程這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI