Click here to view and discuss this page in DocCommentXchange. In the future, you will be sent there automatically.

SQL Anywhere 11.0.1 (中文) » SQL Anywhere 服务器 - SQL 的用法 » 查询和修改数据 » 对查询结果进行汇总、分组和排序 » ORDER BY 子句:查询结果排序

 

显式限制查询返回的行数

可以使用 FIRST 或 TOP 关键字限制查询结果集中包括的行数。这些关键字用于包括 ORDER BY 子句的查询。

示例

以下查询返回在按姓氏对雇员进行排序时首先出现的雇员的信息:

SELECT FIRST *
   FROM Employees
   ORDER BY Surname;

以下查询返回按姓氏排序时出现的前五个雇员:

SELECT TOP 5 *
   FROM Employees
   ORDER BY Surname;

使用 TOP 时,还可以使用 START AT 来提供一个偏移值。以下语句列出了按姓氏以降序进行排序时出现的第五个和第六个雇员:

SELECT TOP 2 START AT 5 *
   FROM Employees
   ORDER BY Surname DESC;

FIRST 和 TOP 应只与 ORDER BY 子句联合使用,以确保获得一致的结果。如果不将 FIRST 或 TOP 与 ORDER BY 联合使用,则会触发语法警告,并可能产生无法预知的结果。

注意

START AT 值必须大于 0。当 TOP 为常量时,其值必须大于 0;当 TOP 为变量时,其值必须大于或等于 0。