亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

SQL Server 存儲過程分頁

2024-08-31 00:55:54
字體:
來源:轉載
供稿:網友
SQL Server 存儲過程分頁

每每面試,總會有公司問到分頁。在下不才,在這里寫幾種分頁,望路過的各位大神盡情拍磚。

先從創建數據庫說起。源碼如下

一.創建數據庫

 1 /********************************************************************** 2                         一.創建數據庫DBTest 3                        @author:    Alex Tian 4                        Create Date:    2014-03-19 5 ***********************************************************************/ 6 use master  --這里我們選擇master數據庫的目的是為了我們可以訪問表 7 --判斷數據庫清單中是否存在數據庫DBTest 8 if exists(select * from sysdatabases where name='DBTest') 9 Drop DataBase DBTest   --刪除數據庫DBTest10 Go11 /*創建數據庫的SQL語句,這里我們就創建DBTest數據庫*/12 Create Database DBTest13 on PRimary  --默認就是primary文件組,可省略14 (15  /*--數據文件的具體描述--*/16       name='DBTest_data',  -- 主數據文件的邏輯名稱17       filename='D:/SQL/DBTest_data.mdf', -- 主數據文件的物理名稱18       size=5mb, --主數據文件的初始大小19       maxsize=100mb, -- 主數據文件增長的最大值20       filegrowth=15%--主數據文件的增長率21  )22  log on23  (24  /*--日志文件的具體描述,各參數含義同上--*/25      name='DBTest_log',26      filename='D:/SQL/DBTest_log.ldf',27      size=2mb,28      filegrowth=1mb29  )

二.創建表

 1 /********************************************************************** 2                         二.創建表Users 3 ***********************************************************************/ 4 use DBTest   --選擇我們剛剛創建的數據庫DBTest 5 Go 6 if Exists (select * from sysobjects where name='Users') 7 Drop Table Users 8 go 9 Create Table Users10 (11     ID int identity(1,1) primary key,  --表示是主鍵自增,標示種子是1.12     UName nvarchar(20) Not null,         --用戶姓名不能為空13     USex  char(2)   --性別14 )

三.插入數據

 1 /********************************************************************** 2                         三.插入數據到表Users 3 ***********************************************************************/ 4 insert into Users 5 select 'yoyo','男' 6 union 7 select 'Alex','男' 8 union  9 select '蘭陽','女'10 union11 select '彭偉','男'12 union13 select '張瓊','男'14 union15 select '肖小仙','女'16 union17 select '毛毛','男'18 union19 select '田勇','男'20 union21 select '田紅','男'22 union23 select '柯麗','女'24 union25 select 'Gross','男'26 union27 select '何軍','男'28 union29 select 'Leo','男'30 union31 select '金瓊','女'32 union33 select '孫龍','男'34 union35 select '老姚','男'36 union37 select '李聰','女'38 union39 select '王超','男'40 union41 select '孫艷','女'42 union43 select '曹瑞','男'44 union45 select '王瓊','女'46 union47 select '沈炎','男'48 union49 select '莊雪月','女'50 union51 select '老丁','男'52 union53 select '景天','男'54 union55 select '雪見','女'56 Go

由于數據量太少,我這里重復插入了上面的測試數據,然后我們查詢當前的表Users 上面都是準備工作,廢話少說。直接插入主題。

1.下面我們用not in語句去分頁,為了方便大家看,直接存儲過程附上。

 1 select top 10 * from Users where (ID not in (select top 20 ID from Users order by ID asc) ) 2  order by ID 3   4  create procedure sp_Page_View_with_not_in 5  ( 6      @pageIndex int,--頁索引。 7      @PageSize int--頁記錄數 8  ) 9  as10  begin11     set nocount on12     declare @strSQL varchar(1000)13     set @strSQL='(select top '+str(@PageSize)+' * from Users where (ID not In (select top '+str(@pageIndex*@PageSize)+' ID from Users order by ID asc)) order by ID)'    14     set nocount off15  end16  --drop procedure Page_View_with_not_in   --刪除存儲過程

2.用Max分頁,源碼如下

 1 --2.使用select top 和select Max(列鍵) 2  3 select top 10 * from Users where  4 ID> 5  ( 6      select MAX(ID) from 7      ( 8         select top 20  ID from Users order by ID 9      ) as temp10  )11 order by ID12 13 --創建存儲過程14  create procedure sp_Page_View_with_Max15  (16     @PageInde int, -- 當前頁索引17     @PageSize int  --每頁要顯示的條數18  )19  as20  begin21     declare @strSQL nvarchar(1000)22     set @strSQL='select top '+str(@PageSize)+' * from Users where ID>(select MAX(ID) from (select top +'+str(@PageInde*@PageSize)+' ID from Users order by ID) as Temp )23     order by ID'24  end25  26 --drop procedure sp_Page_View_with_Max

3.用ROW_NUMBER()分頁(僅支持SQL Server 2005或2005之后的數據庫),源碼如下

 1 --3.利用Row_number()給數據行加索引(適用于,有很多數據表中沒有identity ID的表) 2 --假設我們當前的Users表沒有identity 3 select RID,UName,USex from 4 ( 5 select *,ROW_NUMBER() over (order by ID) as RID  6 from Users 7 ) 8 as tempTable 9 where RID>20 and RID<=3010 11 create procedure sp_Page_View_With_ROW_NUMBER12 (13     @pageIndex int, 14     @pageSize int15 )16 as17 begin18     declare @strSQL nvarchar(1000)19     set @strSQL='select RID,UName,USex from (select *,ROW_NUMBER() over (order by ID asc) as RID from Users) as TempTable20 where RID>'+str(@pageIndex*@pageSize)+' and RID<='+str(@pageSize*(@pageIndex+1))+''    21 end

以上是很常用的幾種分頁,當然還有很多種,比如 用臨時表及Row_number ,互聯網的大神們用select max方法用2分法等等等。這里由于數據量很小,我沒有過多的去考慮性能。在這里我不對性能方面作于評價。僅用于面試之類的孩紙們了解一下。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人手机在线| 国产亚洲a∨片在线观看| 欧美成人一二三| 亚洲字幕一区二区| 国产精品都在这里| 国产精品黄色影片导航在线观看| 亚洲老头同性xxxxx| 日韩av电影在线播放| 欧美日韩国产成人| 一区二区三区在线播放欧美| 亚洲欧洲高清在线| 亚洲第一页中文字幕| 亚洲激情视频在线观看| 国产精品久久久久久久久久ktv| 欧美黑人视频一区| 久久精品国产久精国产一老狼| 美日韩精品免费观看视频| 亚洲精品中文字幕有码专区| 亚洲欧美激情四射在线日| 国产精品一区久久久| 国产精品你懂得| 亚洲视频在线免费看| 最近2019年日本中文免费字幕| 欧美激情一区二区三级高清视频| 欧美孕妇性xx| 欧美日韩在线影院| 777777777亚洲妇女| 成人午夜激情网| 亚洲国产精久久久久久| 亚洲精品99999| 日韩欧美在线一区| 日韩国产精品亚洲а∨天堂免| 亚洲精品乱码久久久久久按摩观| 亚洲国产精品va在线| 欧美日韩国内自拍| 久久成人精品一区二区三区| 亚洲国产中文字幕在线观看| 国产mv久久久| 日韩中文视频免费在线观看| 欧美日韩国产一中文字不卡| 久久久久久久久久国产| 国产精品福利在线观看| 欧美成年人视频网站| 欧美日韩国产精品| 91精品久久久久久久久| 久久这里有精品| 一区二区三区在线播放欧美| 日韩av成人在线观看| 久久成人av网站| 国产精品高潮呻吟久久av野狼| 欧美极品第一页| 欧美电影在线观看高清| 日韩成人在线视频观看| 久久精品久久久久电影| 欧美猛少妇色xxxxx| 久久久久久高潮国产精品视| 91成人精品网站| 伊人青青综合网站| 亚洲天堂av在线免费| 色婷婷av一区二区三区在线观看| 国产精品视频久久久久| 亚洲天堂av综合网| 黄色成人在线播放| 欧美电影免费观看大全| 日韩在线播放视频| 亚洲第一精品久久忘忧草社区| 久久久av电影| 精品国偷自产在线视频99| 中文字幕亚洲一区二区三区五十路| 欧美日韩国产精品一区二区三区四区| 日本一本a高清免费不卡| 久久久久久久久国产精品| 欧美精品激情在线观看| 亚洲精品国精品久久99热一| 久久av在线看| 亚洲欧美成人一区二区在线电影| 欧美成人激情视频免费观看| 亚洲福利影片在线| 九九精品视频在线| 久久激情视频免费观看| 中文字幕欧美亚洲| 亚洲国产另类久久精品| 91精品国产自产91精品| 欧美激情视频网站| 少妇精69xxtheporn| 欧美天天综合色影久久精品| 欧美日韩不卡合集视频| 亚洲欧洲一区二区三区在线观看| 亚洲国产日韩欧美在线图片| 亚洲男人天堂网站| 国产区精品视频| 亚洲欧美日韩国产中文专区| 色av中文字幕一区| 国产欧美日韩免费看aⅴ视频| 国产一区二区三区视频| 中国日韩欧美久久久久久久久| 久久人人爽人人爽人人片亚洲| 国产精品久久久久久久久男| 国产精品欧美久久久| 久久av在线播放| 亚洲欧美中文日韩在线v日本| 国产一级揄自揄精品视频| 欧美日韩亚洲视频| 狠狠躁夜夜躁人人躁婷婷91| 北条麻妃一区二区三区中文字幕| 久久韩国免费视频| 久久人人爽人人| 一区二区三区四区视频| 在线一区二区日韩| 91精品啪在线观看麻豆免费| 97视频在线观看免费| 亚洲a∨日韩av高清在线观看| 精品福利免费观看| 国产mv免费观看入口亚洲| 亚洲天堂av图片| 亚洲九九九在线观看| 91精品国产91久久久久久不卡| 亚洲精品福利在线观看| 国产精品成人aaaaa网站| 国产va免费精品高清在线观看| 成人av在线亚洲| 精品无人国产偷自产在线| 欧美第一黄网免费网站| 精品成人乱色一区二区| 国产日韩精品入口| 亚洲激情自拍图| 欧美激情国产日韩精品一区18| 久久69精品久久久久久国产越南| 一区二区三区动漫| 国产婷婷色综合av蜜臀av| 亚洲的天堂在线中文字幕| 国产69精品99久久久久久宅男| 国产欧美日韩亚洲精品| 欧美亚洲激情在线| 欧美黑人狂野猛交老妇| 亚洲自拍欧美另类| 91久久久国产精品| 国产精品久久在线观看| 欧美片一区二区三区| 国产日韩换脸av一区在线观看| 欧美夫妻性生活视频| 国产激情久久久久| 久久精品国产一区二区电影| 久久99热这里只有精品国产| 午夜精品久久久久久久99黑人| 国产欧美精品久久久| 国产精品人成电影在线观看| 欧美日韩电影在线观看| 久久艳片www.17c.com| 欧美性视频网站| www.日本久久久久com.| 91国偷自产一区二区三区的观看方式| 亚洲国产精品成人av| 亚洲精品美女在线观看| 91九色国产在线| 国产精品人人做人人爽| 91精品免费视频| 久久噜噜噜精品国产亚洲综合| 国产精品久久久久久中文字| 久久视频在线直播| 国产在线观看精品一区二区三区| 欧美在线视频在线播放完整版免费观看| 日日摸夜夜添一区| 久久99精品国产99久久6尤物|