Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

Equivalente a LIMIT em T-SQL


Sql Server 2005 não tem a sintaxe de limite que você tem acima, que não foi adicionada até 2012. Você vai querer usar a cláusula OVER e expressões de tabela comuns.

Exemplo do 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;