国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

SQL Server利用RowNumber()內置函數與Over關鍵字實現通用分頁存儲過程(支持單表或多表結查集分頁)

2024-08-31 00:54:23
字體:
來源:轉載
供稿:網友
SQL Server利用RowNumber()內置函數與Over關鍵字實現通用分頁存儲過程(支持單表或多表結查集分頁)

SQL Server利用RowNumber()內置函數與Over關鍵字實現通用分頁存儲過程,支持單表或多表結查集分頁,存儲過程如下:

/******************/--Author:夢在旅途(www.Zuowenjun.cn)--CreateDate:2015-06-02--Function:分頁獲取數據/******************/create PRocedure [dbo].[sp_DataPaging](@selectsqlnvarchar(200),--查詢字段SQL,不含select,支持靈活寫法,如:col1,col3,isnull(col4,'') as col4@fromsqlnvarchar(500),--查詢表及條件SQL,不含from,若包含條件請加上where,如:table where col1='test'@orderbysql nvarchar(100),--查詢排序SQL,不含order by,如:id order by desc@pagesizeint=20,--每頁顯示記錄數@pagenoint=1,--當前查詢頁碼,從1開始@returnrecordcount bit=1 --是否需要返回總記錄數,若設為1,則返回兩個結果表)asbegindeclare @sqlcount nvarchar(500),@sqlstring nvarchar(max)set @sqlstring=N'from (select row_number() over (order by ' + @orderbysql + N') as rowId,' + @selectsql + N' from '+ @fromsql +N') as t'if(@returnrecordcount=1)beginset @sqlcount=N'select count(rowId) as resultcount ' + @sqlstringexec(@sqlcount)endset @sqlstring=N'select * ' + @sqlstring + ' where rowId between ' + convert(nvarchar(50),(@pageno-1)*@pagesize+1)+' and '+convert(nvarchar(50),@pageno*@pagesize)exec(@sqlstring)end

 用法如下:

--單表查詢exec [dbo].[sp_DataPaging] '*','AssetDetail','assetsingleno',10,1--多表查詢exec [dbo].[sp_DataPaging] 'a.*','Inventory a left join AssetDetail b on a.StoreNo=b.StoreNo and a.CompanyID=b.CompanyIDinner join Asset c on b.AssetID=c.ID and b.CompanyID=c.CompanyID','a.id',20,3,1

結果顯示如下(如上多表查詢):


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 衡阳县| 柯坪县| 博白县| 鱼台县| 留坝县| 宁陕县| 安达市| 德惠市| 施甸县| 旬阳县| 筠连县| 洱源县| 绵阳市| 博爱县| 上犹县| 长春市| 志丹县| 昌邑市| 阿城市| 玛曲县| 徐闻县| 鄂尔多斯市| 古蔺县| 中阳县| 元阳县| 澎湖县| 宣城市| 白玉县| 海晏县| 舒兰市| 浮山县| 安图县| 西乌珠穆沁旗| 仲巴县| 平昌县| 玉环县| 阿克| 临沧市| 瓦房店市| 兴海县| 容城县|