Вернуть страницу с результатами полнотекстового поиска, не прибегая к помощи?

У меня есть запрос, похожий на следующий, для возврата статей, соответствующих полнотекстовому поиску. В производственной среде текст [КРИТЕРИИ ПОЛНОГО ПОИСКА] заменяется фактическим выражением полнотекстового поиска.

Запрос написан так, чтобы возвращать только одну страницу результатов.

WITH ArtTemp AS (
  SELECT TOP (@StartRow + @MaxRows) ROW_NUMBER() OVER (ORDER BY ArtViews DESC) AS RowID,
  Article.ArtID,Article.ArtTitle,Article.ArtSlug,Category.CatID,Category.CatTitle,
  Article.ArtDescription,Article.ArtCreated,Article.ArtUpdated,Article.ArtUserID,
  [User].UsrDisplayName AS UserName FROM Article
  INNER JOIN Subcategory ON Article.ArtSubcategoryID = Subcategory.SubID
  INNER JOIN Category ON Subcategory.SubCatID = Category.CatID
  INNER JOIN [User] ON Article.ArtUserID = [User].UsrID
  WHERE [FULL TEXT SEARCH CRITERIA] AND Article.ArtApproved = 1
)

SELECT ArtID,ArtTitle,ArtSlug,CatID,CatTitle,ArtDescription,ArtCreated,ArtUpdated,
ArtUserID,UserName FROM ArtTemp
WHERE RowID BETWEEN @StartRow + 1 AND (@StartRow + @MaxRows)
ORDER BY RowID 

Это работает нормально, за исключением этот полнотекстовый поиск возвращает результаты в порядке релевантности, но ROW_NUMBER () OVER (ORDER BY ArtViews DESC) преобразует результаты. Есть ли способ написать тот же запрос, не прибегая к результатам?

6
задан Jonathan Wood 11 June 2011 в 21:31
поделиться