OPTIMIZE FOR N ROWS是一个DB2子句,我们可以在查询中添加该子句以仅优先检索前几行。此子句将使优化程序选择访问路径,以最小化获取前几行的响应时间。
OPTIMIZE FOR N ROWS子句对SELECT DISTINCT和COUNT函数无效,因为DB2将需要整个限定行才能获取DISTINCT行或COUNT行数。OPTIMIZE FOR N ROWS子句为DB2提供了建立访问路径的更好机会。
如下所示,可以在SQL查询中使用OPTIMIZE FOR N rows子句。
SELECT ORDER_ID, ORDER_TOTAL FROM ORDERS ORDER BY ORDER_TOTAL DESC OPTIMIZE FOR 2 ROWS
我们将仅使用“ FETCH FIRST n ROWS”限制返回的行数,并且不会考虑合格行的实际数。
我们可以使用OPTIMIZE FOR N ROWS的实际情况是CICS屏幕,在这里我们只能显示5个订单的列表。
SELECT ORDER_ID, ORDER_TOTAL FROM ORDERS ORDER BY ORDER_TOTAL DESC OPTIMIZE FOR 5 ROWS
例如,我们的DB2 ORDERS表具有以下数据。
ORDER_ID | INVOICE_ID |
IRN22345 | Z451189 |
IRN89767 | Z451189 |
IRN67331 | Z955189 |
IRN56902 | Z225184 |
IRN99781 | Z896671 |
IRN09863 | Z225184 |
IRN34119 | Z094711 |
IRN10933 | Z189112 |
IRN67114 | Z009117 |
IRN31990 | Z551891 |
我们的OPTIMIZE FOR 5 ROWS查询的结果将如下所示。
ORDER_ID | INVOICE_ID |
IRN99781 | Z896671 |
IRN89767 | Z451189 |
IRN67331 | Z955189 |
IRN67114 | Z009117 |
IRN56902 | Z225184 |