跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • Oracle 如何让搜索条件逐层递进?子查询会被自动优化
未分類
10 1 月 2021

Oracle 如何让搜索条件逐层递进?子查询会被自动优化

Oracle 如何让搜索条件逐层递进?子查询会被自动优化

資深大佬 : black11black 2

如题,建了一张测试表,大概十亿行,业务上想让搜索逐层递进,比如先从总表中选出 user_id(主键,分区键) 为 10086 的用户的所有行,然后再进一步选择其中 timestamp(第二主键)在 2020 年 1 月 1 日-2021 年 1 月 1 日期间的所有行,诸如此类,逐层递进。

在以往使用 mysql 的过程中,经验是只要把搜索条件按顺序排好,mysql 是会按照顺序执行的。但是到 oracle 之后,发现 oracle 会自动优化,无论搜索条件谁先谁后,首先都会根据 timestamp,选取区段内所有行,然后再识别 userid,可能是因为 timestamp 上有全局索引的缘故,但是显然没有分区键搜索效率高,速度慢了一个量级。

而后尝试用子查询的方式,先筛选 userid,再筛选时间,打开解释器后发现 oracle 解释出来的语句完全没有变化。

那业务上要如何实现这种查询以优化速度呢?

大佬有話說 (1)

  • 主 資深大佬 : black11black

    ——————————————————————————————————————————–
    | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | Pstart| Pstop |
    ——————————————————————————————————————————–
    | 0 | SELECT STATEMENT | | 1 | 22 | 0 (0)| 00:00:01 | | |
    | 1 | SORT AGGREGATE | | 1 | 22 | | | | |
    |* 2 | TABLE ACCESS BY GLOBAL INDEX ROWID BATCHED| USERMAP | 4388 | 96536 | 0 (0)| 00:00:01 | 1 | 1 |
    |* 3 | INDEX RANGE SCAN | INDEX_TIMESTAMP | 12M| | 0 (0)| 00:00:01 | | |
    ——————————————————————————————————————————–

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具