/
TOP Clause

TOP Clause

The number of results returned by a query can be limited by TOP, followed by an expression with a non-negative integer.

SELECT TOP 100 [r]
FROM [invoice] AS [r]

The ORDER BY clause rarely makes sense without a TOP clause. If you would like your query to return the 100 invoices with the highest amounts, this can be formulated in the following way.

SELECT TOP 100 [r]
FROM [invoice] AS [r]
ORDER BY [amount] DESC

More complex expressions are also possible. All invoices except the 100 with the lowest amount can therefore be selected.

SELECT TOP (SELECT count(*)-100 FROM [invoice]) [r]
FROM [invoice] AS [r]
ORDER BY [amount] DESC

The statement only works if there are at least 100 invoices, i.e., the expression after TOP is a non-negative number.

The TOP clause is only possible in outermost queries, not in subselects and not in partial queries linked by UNION or EXCEPT.