最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

sqlserver支持定位當(dāng)前頁,自定義排序的分頁SQL(拒絕動態(tài)SQL)

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-09 07:12:34
文檔

sqlserver支持定位當(dāng)前頁,自定義排序的分頁SQL(拒絕動態(tài)SQL)

sqlserver支持定位當(dāng)前頁,自定義排序的分頁SQL(拒絕動態(tài)SQL):1,場景:根據(jù)學(xué)生編號查詢,返回該學(xué)生所在班級的所有學(xué)生。支持分頁、自定義排序及結(jié)果集自動定位到查詢條件的學(xué)生編號所在頁。 代碼如下: CREATE PROC [dbo].[Sp_testpagerandsorting] (@GroupID INT, @CurrentId INT, @Time
推薦度:
導(dǎo)讀sqlserver支持定位當(dāng)前頁,自定義排序的分頁SQL(拒絕動態(tài)SQL):1,場景:根據(jù)學(xué)生編號查詢,返回該學(xué)生所在班級的所有學(xué)生。支持分頁、自定義排序及結(jié)果集自動定位到查詢條件的學(xué)生編號所在頁。 代碼如下: CREATE PROC [dbo].[Sp_testpagerandsorting] (@GroupID INT, @CurrentId INT, @Time

1,場景:根據(jù)學(xué)生編號查詢,返回該學(xué)生所在班級的所有學(xué)生。支持分頁、自定義排序及結(jié)果集自動定位到查詢條件的學(xué)生編號所在頁。
代碼如下:
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,簡單條件的,動態(tài)where語句(關(guān)于Like查詢的動態(tài)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

您可能感興趣的文章:

  • 基于Oracle的高性能動態(tài)SQL程序開發(fā)
  • 為什么ASP中執(zhí)行動態(tài)SQL總報錯誤信息?提示語句語法錯誤
  • 批處理 動態(tài)sql
  • 動態(tài)SQL語句使用心得
  • 編程經(jīng)驗點滴 動態(tài)SQL的拼接技巧
  • oracle中動態(tài)SQL使用詳細(xì)介紹
  • mysql存儲過程 在動態(tài)SQL內(nèi)獲取返回值的方法詳解
  • MySQL 存儲過程中執(zhí)行動態(tài)SQL語句的方法
  • mybatis的動態(tài)sql詳解(精)
  • 聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    sqlserver支持定位當(dāng)前頁,自定義排序的分頁SQL(拒絕動態(tài)SQL)

    sqlserver支持定位當(dāng)前頁,自定義排序的分頁SQL(拒絕動態(tài)SQL):1,場景:根據(jù)學(xué)生編號查詢,返回該學(xué)生所在班級的所有學(xué)生。支持分頁、自定義排序及結(jié)果集自動定位到查詢條件的學(xué)生編號所在頁。 代碼如下: CREATE PROC [dbo].[Sp_testpagerandsorting] (@GroupID INT, @CurrentId INT, @Time
    推薦度:
    標(biāo)簽: 定位 自定義 自定義排序
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top