在我的web应用程序中,我使用下面的SQL过程获取用于JqGrid分页的数据。
ALTER PROCEDURE [dbo].[NewStoredProc]
(
@skip int,
@pageSize int,
@OrderBy Varchar(20),
@OrderByDirection Varchar(10)
)
AS
BEGIN
DECLARE @records int;
SET NOCOUNT ON;
SET @records =(select count(*) from Data where Status='A');
IF @skip <= 0
SELECT TOP (@pageSize) * from Data where Status='A'
ORDER BY CASE WHEN @OrderBy='Column1' AND @OrderByDirection='D' THEN Column1 END DESC ,CASE WHEN @OrderBy='Column1' AND @OrderByDirection !='D'THEN Column1 END,
CASE WHEN @OrderBy='Column2' AND @OrderByDirection='D' THEN Column2 END DESC ,CASE WHEN @OrderBy='Column2' AND @OrderByDirection !='D'THEN Column2 END,
CASE WHEN @OrderBy='Column3' AND @OrderByDirection='D' THEN Column3 END DESC ,CASE WHEN @OrderBy='Column3' AND @OrderByDirection !='D'THEN Column3 END
ELSE
WITH GetAll AS (
SELECT * from Data where Status='A')
,GetFirst AS (
SELECT TOP (@skip) *
FROM GetAll
),GetNext AS (
SELECT TOP (@pageSize) nt.*
FROM GetAll AS nt
LEFT OUTER JOIN GetFirst AS f ON f.Col1=nt.Col1
WHERE f.Col1 IS NULL)
SELECT * FROM GetNext;
RETURN @records;
END在这里,问题是我不能在子句中使用OrderBy。但是,我只需要在sorting.Is之后才能拿到记录。
简单地说..。如何实现GetAll数据的order
发布于 2013-10-11 15:27:10
在我看来,您可以通过在OrderBy中使用GetFirst和WITH子句的GetNext部分来修复代码,但是在GetAll部分使用而不是。相应的代码将涉及以下内容
ALTER PROCEDURE [dbo].[NewStoredProc]
(
@skip int,
@pageSize int,
@OrderBy Varchar(20),
@OrderByDirection Varchar(10)
)
AS
BEGIN
DECLARE @records int;
SET NOCOUNT ON;
SET @records =(select count(*) from Data where Status='A');
IF @skip <= 0
SELECT TOP (@pageSize) * from Data where Status='A'
ORDER BY CASE WHEN @OrderBy='Column1' AND @OrderByDirection='D'
THEN Column1
END DESC,
CASE WHEN @OrderBy='Column1' AND @OrderByDirection !='D'
THEN Column1
END,
CASE WHEN @OrderBy='Column2' AND @OrderByDirection='D'
THEN Column2
END DESC,
CASE WHEN @OrderBy='Column2' AND @OrderByDirection !='D'
THEN Column2
END,
CASE WHEN @OrderBy='Column3' AND @OrderByDirection='D'
THEN Column3
END DESC,
CASE WHEN @OrderBy='Column3' AND @OrderByDirection !='D'
THEN Column3
END
ELSE
WITH GetAll AS (
SELECT * from Data where Status='A'
),GetFirst AS (
SELECT TOP (@skip) *
FROM GetAll
ORDER BY CASE WHEN @OrderBy='Column1' AND @OrderByDirection='D'
THEN Column1
END DESC,
CASE WHEN @OrderBy='Column1' AND @OrderByDirection !='D'
THEN Column1
END,
CASE WHEN @OrderBy='Column2' AND @OrderByDirection='D'
THEN Column2
END DESC,
CASE WHEN @OrderBy='Column2' AND @OrderByDirection !='D'
THEN Column2
END,
CASE WHEN @OrderBy='Column3' AND @OrderByDirection='D'
THEN Column3
END DESC,
CASE WHEN @OrderBy='Column3' AND @OrderByDirection !='D'
THEN Column3
END
),GetNext AS (
SELECT TOP (@pageSize) nt.*
FROM GetAll AS nt
LEFT OUTER JOIN GetFirst AS f ON f.Col1=nt.Col1
WHERE f.Col1 IS NULL
ORDER BY CASE WHEN @OrderBy='Column1' AND @OrderByDirection='D'
THEN nt.Column1
END DESC,
CASE WHEN @OrderBy='Column1' AND @OrderByDirection !='D'
THEN nt.Column1
END,
CASE WHEN @OrderBy='Column2' AND @OrderByDirection='D'
THEN nt.Column2
END DESC,
CASE WHEN @OrderBy='Column2' AND @OrderByDirection !='D'
THEN nt.Column2
END,
CASE WHEN @OrderBy='Column3' AND @OrderByDirection='D'
THEN nt.Column3
END DESC,
CASE WHEN @OrderBy='Column3' AND @OrderByDirection !='D'
THEN nt.Column3
END
)
SELECT * FROM GetNext
RETURN @records;
ENDhttps://stackoverflow.com/questions/19320816
复制相似问题