首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >表索引是否会影响SQL join查询的执行时间?

表索引是否会影响SQL join查询的执行时间?
EN

Stack Overflow用户
提问于 2012-10-22 21:34:54
回答 1查看 1.9K关注 0票数 2

我有一个存储过程,其中包括4-5个表连接操作,SP I在两个不同数据库(所有表定义都相同)上执行,那么在DB-1中,SP需要20-25秒,在DB-2 SP中需要1秒执行,然后在我重建DB-1索引后,DB-1的SP比以前工作得更快。

那么,连接和表索引间有什么关系吗?如果是,那么如何解决这类问题呢?

EN

回答 1

Stack Overflow用户

发布于 2012-10-22 21:55:50

我理解您的问题,即使用索引是否会影响连接性能。答案是响亮的“是”。

通常,连接到只需要几行的表将使用索引(如果存在)。

连接到需要大部分表的表将导致“全表扫描”(Oracle术语),其中DBMS将使用此作为索引来构建连接键的散列,以便随后在连接时探测要使用的正确值。

请参阅http://en.wikipedia.org/wiki/Join_%28SQL%29#Implementation和它引用的关于连接算法的文章,以获得有关这些算法的良好概述。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13012596

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档