Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Equivalente di LIMIT in T-SQL

Sql Server 2005 non ha la sintassi limite che hai sopra, che non è stata aggiunta fino al 2012. Ti consigliamo di utilizzare la clausola OVER e le espressioni di tabella comuni.

Esempio da SqlTeam

WITH Members  AS
(
    SELECT  M_NAME, M_POSTS, M_LASTPOSTDATE, M_LASTHEREDATE, M_DATE, M_COUNTRY,
            ROW_NUMBER() OVER (ORDER BY M_POSTS DESC) AS RowNumber
    FROM    dbo.FORUM_MEMBERS
)
SELECT  RowNumber, M_NAME, M_POSTS, M_LASTPOSTDATE, M_LASTHEREDATE, M_DATE, M_COUNTRY
FROM    Members
WHERE   RowNumber BETWEEN 1 AND 20
ORDER BY RowNumber ASC;