开发者社区> 问答> 正文

如何查询具有最高性能的DB2中的数据范围?

通常,我需要从某个范围的表中检索数据。例如,每个搜索结果都有一个单独的页面。在MySQL中,我使用LIMIT关键字,但在DB2中,我不知道。现在,我使用此查询来检索数据范围。

SELECT * FROM( SELECT
SMALLINT(RANK() OVER(ORDER BY NAME DESC)) AS RUNNING_NO , DATA_KEY_VALUE , SHOW_PRIORITY FROM EMPLOYEE WHERE NAME LIKE 'DEL%' ORDER BY NAME DESC FETCH FIRST 20 ROWS ONLY ) AS TMP ORDER BY TMP.RUNNING_NO ASC FETCH FIRST 10 ROWS ONLY 但我知道这是不好的风格。那么,如何查询最高性能呢?

问题来源于stack overflow

展开
收起
保持可爱mmm 2019-11-18 16:32:41 631 0
1 条回答
写回答
取消 提交回答
  • 我的需求已经添加到DB2 9.7.2中了。

    DB2 9.7.2为限制查询结果添加了新的语法,如下所示:

    SELECT * FROM TABLE LIMIT 5 OFFSET 20 数据库将从第no行检索结果。21-25

    2019-11-18 16:32:50
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
PolarDB NL2SQL: 帮助您写出准确、优化的SQL 立即下载
MySQL表和索引优化实战 立即下载
HTAP DB HTAP DB —System : ApsaraDB HBase Phoenix and Spark 立即下载