1
我想做一個存儲過程得到分頁排序結果,但這裏是扭曲。我必須添加一列並填充計算/計算的數據。目前,我有存儲過程得到分頁排序的結果與計算的數據列
ALTER proc [dbo].[pr_GetPagedSortedOrdersByUser]
(
@userid numeric(18,0),
@CurrentPage int,
@PageSize int,
@SortField varchar(200),
@SortOrder varchar(5),
@status varchar(50)
)
as
begin
with temp as
(
select *
,ROW_NUMBER() OVER (order by
CASE WHEN @SortField = 'orderdate' AND @SortOrder = 'Desc' THEN orderdate END DESC,
CASE WHEN @SortField = 'orderdate' THEN orderdate END,
CASE WHEN @SortField = 'netamount' AND @SortOrder = 'Desc' THEN netamount END DESC,
CASE WHEN @SortField = 'netamount' THEN netamount END,
CASE WHEN @SortField = 'id' AND @SortOrder = 'Desc' THEN id END DESC,
CASE WHEN @SortField = 'id' THEN id END
) AS ROWID
from tbOrder
where (@status='All' or [email protected])and [email protected]
)
select * ,
(
netamount - discount
) as 'Gross'
from temp
where rowid>((@CurrentPage - 1) * @PageSize) and rowid <(@CurrentPage * @PageSize + 1)
select count(*) as [count]
from tbOrder
where ([email protected] or @status='All')and [email protected]
end
注:Gross
列不存在於數據庫中,我應該能值Gross
傳遞給@SortField
感謝隊友它工作 – 2012-02-16 06:35:21