如题,建了一张测试表,大概十亿行,业务上想让搜索逐层递进,比如先从总表中选出 user_id(主键,分区键) 为 10086 的用户的所有行,然后再进一步选择其中 timestamp(第二主键)在 2020 年 1 月 1 日-2021 年 1 月 1 日期间的所有行,诸如此类,逐层递进。
在以往使用 mysql 的过程中,经验是只要把搜索条件按顺序排好,mysql 是会按照顺序执行的。但是到 oracle 之后,发现 oracle 会自动优化,无论搜索条件谁先谁后,首先都会根据 timestamp,选取区段内所有行,然后再识别 userid,可能是因为 timestamp 上有全局索引的缘故,但是显然没有分区键搜索效率高,速度慢了一个量级。
而后尝试用子查询的方式,先筛选 userid,再筛选时间,打开解释器后发现 oracle 解释出来的语句完全没有变化。
那业务上要如何实现这种查询以优化速度呢?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.