SQL Server (Transact-SQL) TOP 子句用于从表中获取指定数量或百分比的记录。当表包含数千条记录并且返回大型数据集会影响性能时,这非常有用。
SQL Server TOP 子句用于数据库的分页查询。
语法
下面给出了在 SQL Server (Transact-SQL) 中使用 TOP 子句的语法:
SELECT TOP number|percent column1, column2, ...
FROM table_name
WHERE condition(s);
示例:
考虑一个数据库,其中包含一个名为 Employee 的表,其中包含以下记录:
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
1 | John | London | 25 | 3000 |
2 | Marry | New York | 24 | 2750 |
3 | Jo | Paris | 27 | 2800 |
4 | Kim | Amsterdam | 30 | 3100 |
5 | Ramesh | New Delhi | 28 | 3000 |
6 | Huang | Beijing | 28 | 2800 |
要从 Employee 表中获取前 3 条记录,查询为:
SELECT TOP 3 * FROM Employee;
这将产生如下所示的结果:
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
1 | John | London | 25 | 3000 |
2 | Marry | New York | 24 | 2750 |
3 | Jo | Paris | 27 | 2800 |
上述结果也可以通过在查询中使用 PERCENT 关键字来实现。
SELECT TOP 50 PERCENT * FROM Employee;
以下代码的结果将是:
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
1 | John | London | 25 | 3000 |
2 | Marry | New York | 24 | 2750 |
3 | Jo | Paris | 27 | 2800 |
要获取员工 年龄 大于 25 的前 3 条记录,查询将是:
SELECT TOP 3 * FROM Employee
WHERE Age > 25;
这将产生如下所示的结果:
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
3 | Jo | Paris | 27 | 2800 |
4 | Kim | Amsterdam | 30 | 3100 |
5 | Ramesh | New Delhi | 28 | 3000 |