結果をページ分割するためのクエリがあり、SQL Server 2012では問題なく機能していました。ただし、データベースをSQL Server 2008に移動する必要があり、ストアドプロシージャが機能しなくなりました。調査を行ったところ、SQL Server 2008ではOFFSET
が機能しないことがわかりました。現在、どの代替手段を使用すればよいですか? SQL Server 2008で同じ機能を実現するにはどうすればよいですか?
これが私のストアドプロシージャです:
CREATE PROCEDURE [dbo].[sp_JobSearch]
@EnteredKeyword nvarchar(200) = '',
@EnteredLocation nvarchar(200) = '',
@PageNumber INT = 1,
@PageSize INT = 40
AS
BEGIN
SELECT
MasterJob.Title, MasterJob.CompanyName,
MasterJob.ShortDesc, MasterJob.Url,MasterJob.PostedTime,
MasterJob.Location, JobBoard.JobBoardName
FROM
MasterJob
LEFT JOIN
JobBoard ON MasterJob.JobBoardId = JobBoard.JobBoardId
WHERE
(MasterJob.Title LIKE '%' + @EnteredKeyword + '%')
AND (MasterJob.Location LIKE '%' + @EnteredLocation + '%')
ORDER BY
[MasterJobId]
OFFSET @PageSize * (@PageNumber - 1) ROWS
FETCH NEXT @PageSize ROWS ONLY;
END
共通テーブル式(CTE)を使用します。
CREATE PROCEDURE [dbo].[sp_JobSearch]
@EnteredKeyword nvarchar(200) = '',
@EnteredLocation nvarchar(200) = '',
@PageNumber INT = 1,
@PageSize INT = 40
AS
BEGIN
WITH CTE AS
(
SELECT
ROW_NUMBER() OVER ( ORDER BY [MasterJobId] ) AS RowNum ,
MasterJob.Title, MasterJob.CompanyName, MasterJob.ShortDesc,
MasterJob.Url,MasterJob.PostedTime, MasterJob.Location, JobBoard.JobBoardName
FROM MasterJob
LEFT JOIN JobBoard ON MasterJob.JobBoardId = JobBoard.JobBoardId
WHERE
(MasterJob.Title LIKE '%' + @EnteredKeyword + '%')
AND( MasterJob.Location LIKE '%' + @EnteredLocation + '%' )
)
SELECT
Title, CompanyName, ShortDesc, Url, PostedTime, Location, JobBoardName
FROM CTE
WHERE
(RowNum > @PageSize * (@PageNumber - 1) )
AND
(RowNum <= @PageSize * @PageNumber )
Order By RowNum
END