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

2021-01-07 21:52:39 +08:00
 black11black

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

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

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

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

477 次点击
所在节点    问与答
1 条回复
black11black
2021-01-07 22:03:28 +08:00
--------------------------------------------------------------------------------------------------------------------------------
| 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 | | |
--------------------------------------------------------------------------------------------------------------------------------

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/742697

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX