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

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

sqlserver 支持定位當前頁,自定義排序的分頁SQL(拒絕動態SQL)

2024-08-31 00:58:47
字體:
來源:轉載
供稿:網友
1,場景:根據學生編號查詢,返回該學生所在班級的所有學生。支持分頁、自定義排序及結果集自動定位到查詢條件的學生編號所在頁。

復制代碼 代碼如下:


CREATE PROC [dbo].[Sp_testpagerandsorting] (@GroupID INT,
@CurrentId INT,
@TimeFrom DATETIME,
@TimeTo DATETIME,
@OrderBy CHAR(50),
@PageSize INT,
@CurrentPage INT)
AS
SET nocount ON
BEGIN
DECLARE @StartNumber INT,
@EndNumber INT,
@CurrentIdRowNumber INT,
@RecordCount INT,
@EndPageIndex INT
DECLARE @RowNumberTable TABLE (
rownumber INT IDENTITY (1, 1),
id INT )
--step 1: Build sort id list -------------------------------------------------------
INSERT INTO @RowNumberTable
(id)
SELECT sm.id AS id
FROM dbo.test sm WITH (nolock)
WHERE indate BETWEEN Coalesce(@TimeFrom, indate) AND
Coalesce(@TimeTo, indate)
AND sm.groupid = @GroupID
ORDER BY CASE
WHEN @OrderBy = 'InDate desc' THEN ( Row_number() OVER (ORDER BY indate DESC))
WHEN @OrderBy = 'InDate asc' THEN (Row_number() OVER (ORDER BY indate ASC))
WHEN @OrderBy = 'Id asc' THEN (Row_number() OVER (ORDER BY sm.id ASC))
WHEN @OrderBy = 'Id desc' THEN (Row_number() OVER (ORDER BY sm.id DESC))
WHEN @OrderBy = 'Name asc' THEN (Row_number() OVER (ORDER BY sm.name ASC))
WHEN @OrderBy = 'Name desc' THEN (Row_number() OVER (ORDER BY sm.name DESC) )
END
--step 2: Reset page index with current id -----------------------------------------
IF @CurrentIdNumber > 0
BEGIN
SELECT TOP 1 @CurrentIdRowNumber = rownumber
FROM @RowNumberTable
WHERE id = @CurrentIdNumber
IF @CurrentIdRowNumber > 0
BEGIN
IF @CurrentPage = 0
BEGIN
SET @CurrentPage = Ceiling(CAST(@CurrentIdRowNumber AS DECIMAL) / CAST (@PageSize AS DECIMAL))
END
END
END
ELSE
BEGIN
IF @CurrentPage = 0
BEGIN
SET @CurrentPage = 1
END
END
--step 3: Set recordCount -----------------------------------------
SELECT @RecordCount = COUNT(1)
FROM @RowNumberTable
--step 4: Calc startNumber & endNumber -----------------------------------------
SELECT @StartNumber = @PageSize * ( @CurrentPage - 1 ),
@EndNumber = @PageSize * ( @CurrentPage - 1 ) + @pageSize,
@EndPageIndex = Ceiling(CAST(@RecordCount AS DECIMAL) / CAST(@PageSize AS DECIMAL))
IF @CurrentPage = @EndPageIndex
BEGIN
SET @EndNumber = @RecordCount
END
--step 5: Get sorted id of current page -----------------------------------------
;WITH a
AS (SELECT TOP (@EndNumber - @StartNumber) id,
rownumber
FROM (SELECT TOP (@EndNumber) id,
rownumber
FROM @RowNumberTable) AS b
ORDER BY rownumber DESC)
--step 6: Return current page idList -------------------------------------------------------
SELECT [ID],
[GroupID] [Name],
[Address]
FROM dbo.test sm WITH(nolock)
INNER JOIN a
ON a.id = sm.id
ORDER BY a.rownumber
-- step 7:return current page & record count ----------------------------------
SELECT @CurrentPage AS currentpage,
@RecordCount AS recordcount
END


2,簡單條件的,動態where語句(關于Like查詢的動態where,建議使用笨辦法做)

復制代碼 代碼如下:


CREATE PROC [dbo].[Getstudentlistbycondition] @Name NVARCHAR(20),
@Class INT
AS
SET nocount ON
BEGIN
BEGIN
SELECT [Name],
[class]
FROM [testtable]
WHERE [Class] = CASE
WHEN @Class > 0 THEN @Class ELSE [Class] END
AND [name] = CASE
WHEN @Name <> '' THEN @Name ELSE [Name] END
END
END

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品亚洲欧美导航| 欧美特黄级在线| 久久九九免费视频| 国产精品com| 午夜精品www| 久久精品亚洲94久久精品| 日韩欧美在线中文字幕| 欧美xxxx做受欧美.88| 亚洲视频电影图片偷拍一区| 国产精品久久久久久久久久东京| 亚洲一区二区自拍| 精品亚洲一区二区三区| 日本成熟性欧美| 日韩精品中文字| 成人免费福利视频| 一本一本久久a久久精品牛牛影视| 夜夜嗨av色一区二区不卡| 中文一区二区视频| 精品香蕉一区二区三区| 国产精品一区二区电影| 国产精品美女久久久免费| 久久影院中文字幕| 亚洲免费av网址| 伊人一区二区三区久久精品| 91久久精品一区| 456国产精品| 91高潮精品免费porn| 精品欧美国产一区二区三区| 欧美日韩激情网| 久久精品国产欧美激情| 欧美小视频在线观看| 欧美日韩国产专区| 日韩中文字幕不卡视频| 色妞欧美日韩在线| 91免费在线视频| 91高清视频免费观看| 午夜精品久久久久久久久久久久| 亚洲人成在线一二| 日韩电影中文字幕在线观看| 欧美日韩国产一中文字不卡| 久久久久久国产| www.欧美精品| 国产精品久久色| 91精品视频在线免费观看| 亚洲经典中文字幕| 亚洲无限av看| 最新国产成人av网站网址麻豆| 成人欧美一区二区三区黑人| 精品一区二区亚洲| 九九热r在线视频精品| 蜜臀久久99精品久久久无需会员| 国产精品扒开腿做爽爽爽视频| 久久久久久69| 欧美丰满少妇xxxx| 欧美精品一区二区三区国产精品| 欧美裸体视频网站| 97精品视频在线| 亚洲iv一区二区三区| 国产成人精品综合久久久| 欧美日本亚洲视频| 欧美亚洲第一页| 国内揄拍国内精品少妇国语| 欧美激情视频一区二区| 欧美日韩在线视频观看| 日本免费久久高清视频| 亚洲一级黄色片| 亚洲白虎美女被爆操| 国产精品视频久久久久| 国产精品国产亚洲伊人久久| www.久久久久久.com| 国模精品视频一区二区| 日韩视频免费中文字幕| 亚洲欧美精品一区二区| 欧洲亚洲在线视频| 日本欧美中文字幕| www.99久久热国产日韩欧美.com| 日韩最新在线视频| 亚洲石原莉奈一区二区在线观看| 国产精品视频中文字幕91| 亚洲人成网在线播放| 国产精品久久在线观看| 欧美xxxx18性欧美| 欧美专区在线观看| 亚洲欧洲午夜一线一品| 久久夜色精品国产欧美乱| 91精品久久久久久久久久久| 欧美成在线观看| 欧美日韩午夜激情| xxxxx91麻豆| 亚洲综合自拍一区| 色悠久久久久综合先锋影音下载| 中文国产成人精品| 国产精品99久久久久久www| 91免费观看网站| 日本久久久a级免费| 久久久久久av| 在线日韩日本国产亚洲| 国产一区二区av| 国产免费一区二区三区在线能观看| 午夜精品免费视频| 主播福利视频一区| 欧美制服第一页| 日韩精品中文在线观看| 亚洲美女av网站| 日本中文字幕成人| 亚洲免费av片| 亚洲大胆美女视频| 中国人与牲禽动交精品| 国外成人在线播放| 国产99久久久欧美黑人| 97国产在线观看| 国产91精品黑色丝袜高跟鞋| 曰本色欧美视频在线| 日av在线播放中文不卡| 91中文在线观看| 成人黄色生活片| 91在线精品视频| 欧美乱大交xxxxx另类电影| 久久艹在线视频| 精品中文字幕视频| 久久久久久久久久国产| 久久影院模特热| 国产精品偷伦视频免费观看国产| 亚洲理论在线a中文字幕| 日本最新高清不卡中文字幕| 亚洲欧美日韩一区二区在线| 欧美综合激情网| 欧美国产日本高清在线| 欧美高清视频在线观看| 日韩av在线免费看| 国产亚洲欧洲高清一区| 亚洲欧洲中文天堂| 欧美激情第一页xxx| 日韩欧美中文字幕在线播放| 91精品在线国产| 中文字幕精品在线视频| 日韩福利在线播放| 亚洲一区美女视频在线观看免费| 国产精品嫩草影院久久久| 欧美又大又硬又粗bbbbb| 国产精品专区h在线观看| 亚洲第一网站免费视频| 日韩男女性生活视频| 久久影院在线观看| 欧美日韩国产在线| 亚洲欧美综合区自拍另类| 亚洲天堂男人天堂女人天堂| 久久视频在线播放| 日韩欧美高清视频| 国产精品久久久久久久7电影| 亚洲片国产一区一级在线观看| 国产精品美女www爽爽爽视频| 97碰在线观看| 久久久国产精品免费| 欧美日韩视频免费播放| 久热精品在线视频| 久久香蕉国产线看观看av| 欧美亚洲在线视频| 亚洲国产91色在线| 亚洲最大成人在线| www高清在线视频日韩欧美| 精品久久在线播放| 日韩精品在线免费观看视频| 中文在线资源观看视频网站免费不卡|