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

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

SQL行號排序和分頁(SQL查詢中插入行號 自定義分頁的另類實現)

2024-08-31 00:57:10
字體:
來源:轉載
供稿:網友
(一)行號顯示和排序

1.SQL Server的行號

A.SQL 2000使用identity(int,1,1)和臨時表,可以顯示行號
SELECT
identity(int,1,1) AS ROWNUM,
[DataID]
INTO #1
FROM DATAS
order by DataID;
SELECT * FROM #1
B.SQL 2005提供一個很好用的函數row_number(),
可以直接用來顯示行號,當然也可以使用SQL 2000的identity
SELECT
row_number()over(ORDER BY DataID) AS ROWNUM,
[DataID]
FROM DATAS;
這里如果添加排序功能,則先排序再添加行號

2.ORACLE的行號顯示

使用ROWNUM
SELECT
ROWNUM,
[DataID]
FROM DATAS
order by DataID
注意:先加行號再排序,如果想排序好再加行號就要使用子查詢

3.取前n條數據
A.SQL版
select top n [DataID] from DATAS
B.ORACLE版
SELECT
[DataID]
FROM DATAS where ROWNUM<=n
其中,n>=1
ORACLE的ROWNUM不能應用于大于,只能 ROWNUM= 1, 或者<= 大于1 的自然數

(二)SQL分頁的幾種方式
以每頁10條數據為例,查詢第三頁數據,即21-30這些記錄
1.分頁方案一:(利用Not In和SELECT TOP分頁)
語句形式:

復制代碼 代碼如下:


SELECT TOP 10 *
FROM DATAS
WHERE DataID NOT IN
(SELECT TOP 20 DataID
FROM DATAS
ORDER BY DataID)
ORDER BY DataID


2.分頁方案二:(利用ID大于多少和SELECT TOP分頁)
語句形式:

復制代碼 代碼如下:


SELECT TOP 10 *
FROM DATAS
WHERE ID >
(SELECT MAX(DataID)
FROM (SELECT TOP 20 DataID
FROM DATAS
ORDER BY DataID) AS T)
ORDER BY DataID


3.分頁方案三

復制代碼 代碼如下:


select top 10 DataID from
(SELECT top 30
[DataID]
FROM DATAS
order by dataid desc) A
ORDER BY DataID


4.分頁方案四:(利用SQL的游標存儲過程分頁)

復制代碼 代碼如下:


create procedure SqlPager
@sql nvarchar(8000), --查詢字符串
@curpage int, --第N頁
@pagesize int --每頁行數
as
set nocount on
declare @P int, --P是游標的id
@rowcount int
exec sp_cursoropen @P output,@sql,@scrollopt=1,@ccopt=1, @rowcount=@rowcount output
select ceiling(1.0*@rowcount/@pagesize) as 總頁數,@rowcount as 總行數,@curpage as 當前頁
set @curpage=(@curpage-1)*@pagesize+1
exec sp_cursorfetch @P,16,@curpage,@pagesize
exec sp_cursorclose @P
set nocount off



方法整理如下:
  代碼基于pubs樣板數據庫
  在SQL中,一般就這兩種方法.
  1.使用臨時表
  可以使用select into 創建臨時表,在第一列,加入Identify(int,1,1)作為行號,
  這樣在產生的臨時表中,結果集就有了行號.也是目前效率最高的方法.
  這種方法不能用于視圖

復制代碼 代碼如下:


  set nocount on
  select IDentify(int,1,1) 'RowOrder',au_lname,au_fname into #tmp from authors
  select * frm #tmp
  drop table #tmp


  2.使用自連接
  不用臨時表,在SQL語句中,動態的進行排序.這種方法用到的連接是自連接,連接關系一般是
  大于,

復制代碼 代碼如下:


  select rank=count(*), a1.au_lname, a1.au_fname
  from authors a1 inner join authors a2 on a1.au_lname + a1.au_fname >= a2.au_lname + a2.au_fname
  group by a1.au_lname, a1.au_fname
  order by count(*)


  運行結果:
  rank au_lname au_fname
  ----------- ---------------------------------------- --------------------
  1 Bennet Abraham
  2 Blotchet-Halls Reginald
  3 Carson Cheryl
  4 DeFrance Michel
  5 del Castillo Innes
  6 Dull Ann
  7 Greene Morningstar
  ... ....
缺點:
  1.使用自聯接,所以該方法不適用于處理大量行。它適用于處理幾百行。
  對于大型表,一定要使用索引以避免進行大范圍的搜索,或用第一種方法.
  2.不能正常處理重復值。當比較重復值時,會出現不連續的行編號。
  如果不希望出現這種現象,可以在電子表格中插入結果時隱藏排序列,而是使用電子表格編號。
  或用第一種方法
  優點:
  這些查詢可以用于視圖和結果格式設置中
  在結果集中插入了行號,現在就可以將結果集合緩存起來,然后使用DataView,加入過濾條件
  RowNum>PageIndex*PageSize And RowNum<=(PageIndex+1)*PageSize
  就能實現快速的分頁,而且不論你的頁面數據綁定控件是什么(DataList,DataGrid,還是Repeate都可以)。
  如果你使用的是DataGrid,那么建議不要使用這種技術。因為DataGrid的分頁效率和它差不多。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲日本网站| 亚洲欧美日韩精品久久| 久久全国免费视频| 亚洲乱码av中文一区二区| 伊人亚洲福利一区二区三区| 国产性猛交xxxx免费看久久| 欧日韩不卡在线视频| 在线电影av不卡网址| 亚洲精品久久久久久下一站| 日本久久久久久久久| 亚洲偷熟乱区亚洲香蕉av| 色综合导航网站| 亚洲欧洲在线看| 最近2019好看的中文字幕免费| 亚洲色图35p| 欧美性xxxxx| 日韩美女免费视频| 欧美性xxxx极品hd欧美风情| 青草青草久热精品视频在线观看| 国产精品久久久久久久app| 国产精品久久久久久久app| 亚洲人成在线电影| 久久在线观看视频| 国产精品主播视频| 国产精品日本精品| 啊v视频在线一区二区三区| 亚洲毛片在线免费观看| 国产成人在线视频| 日韩在线观看网址| 久久久久国产视频| 国产一区二区三区高清在线观看| 欧美国产视频日韩| 精品美女久久久久久免费| 91精品国产自产在线| 亚洲精品成人网| 亚洲伊人成综合成人网| 国产99视频在线观看| 伊人成人开心激情综合网| 国产成人综合精品| 欧美一级淫片丝袜脚交| 国产91精品视频在线观看| 欧美xxxx18国产| 在线观看欧美日韩| 国产极品jizzhd欧美| 精品亚洲aⅴ在线观看| 伦理中文字幕亚洲| 国产一区二区黑人欧美xxxx| 国产精品白嫩美女在线观看| 成人激情电影一区二区| 亚洲bt欧美bt日本bt| 国产欧美一区二区三区久久| 精品亚洲男同gayvideo网站| 亚洲午夜国产成人av电影男同| 91av成人在线| 国产不卡av在线免费观看| 久久久久久午夜| 亚洲精品国产电影| 久久99视频精品| 69久久夜色精品国产7777| 一道本无吗dⅴd在线播放一区| 亚洲va久久久噜噜噜久久天堂| 欧美日韩另类在线| 国产精品va在线| 91精品成人久久| 粉嫩av一区二区三区免费野| 亚洲美女福利视频网站| 国产一区二区黑人欧美xxxx| 久久露脸国产精品| 日本一区二三区好的精华液| 国产精品亚洲片夜色在线| 九九精品视频在线| 亚洲精品国精品久久99热| 欧洲永久精品大片ww免费漫画| 久久久久久com| 韩国欧美亚洲国产| 国产精品video| 蜜臀久久99精品久久久久久宅男| 国产第一区电影| 亚洲欧美在线磁力| 久久久久久久香蕉网| 国产精品午夜一区二区欲梦| 国产精品丝袜久久久久久不卡| xxxxx成人.com| 91精品久久久久久| 国产成人jvid在线播放| 欧洲成人在线观看| 亚洲女性裸体视频| 国内精品400部情侣激情| 亚洲第一精品久久忘忧草社区| 久久视频在线观看免费| 日韩欧美精品免费在线| 91精品国产免费久久久久久| 亚洲片在线资源| 亚洲最大成人免费视频| 日韩av在线看| 精品国产一区二区在线| 久久影院资源网| 欧美在线一区二区视频| 亚洲免费人成在线视频观看| 欧美在线视频导航| 久久人人爽人人爽爽久久| 成人免费网站在线| 欧美性猛交xxxx富婆弯腰| 欧美成人性生活| 久久久精品一区二区| 亚洲大胆人体在线| 国产v综合ⅴ日韩v欧美大片| 欧美大片在线看免费观看| 91久久久久久久| 亚洲欧洲成视频免费观看| 亚洲人成在线一二| 丝袜亚洲另类欧美重口| 91在线观看免费观看| 欧美裸体xxxx极品少妇软件| 欧美国产日韩一区二区在线观看| 国产在线视频不卡| 欧美肥老妇视频| 欧美午夜无遮挡| 亚洲区bt下载| 日韩高清电影免费观看完整版| 亚洲美女av电影| 欧美电影在线观看| 日韩中文字幕在线观看| y97精品国产97久久久久久| 欧美日韩亚洲激情| 日韩一级黄色av| 欧美性xxxxx极品娇小| 亚洲国产精品久久久久秋霞不卡| 成人激情av在线| 久久久久九九九九| 尤物yw午夜国产精品视频明星| 国产深夜精品福利| 日韩69视频在线观看| 国产精品久久久久久久久久东京| 欧美视频专区一二在线观看| 国产精品96久久久久久又黄又硬| 精品免费在线观看| 高清视频欧美一级| 国产精品入口日韩视频大尺度| 亚洲精品99久久久久| 亚洲精品电影网| 国产美女扒开尿口久久久| 热门国产精品亚洲第一区在线| 亚洲曰本av电影| www.欧美精品| 久久手机精品视频| 欧美成人免费观看| 欧美大片在线看免费观看| 久久久在线视频| 欧美日韩成人精品| 91视频-88av| 青青草99啪国产免费| 日韩中文字幕网站| 午夜精品在线观看| 91在线看www| 亚洲精品mp4| 亚洲午夜激情免费视频| 日韩视频中文字幕| 亚洲国产精品久久| 中国人与牲禽动交精品| 日韩va亚洲va欧洲va国产| 精品人伦一区二区三区蜜桃免费| 一区二区三区日韩在线| 亚洲福利视频在线|