gpt4 book ai didi

performance - FK 上的联接是否比没有 FK 的联接更快?

转载 作者:行者123 更新时间:2023-12-03 23:27:01 27 4
gpt4 key购买 nike

假设我有两张 table ,ab :

a {
pk as int
fk as int
...
}

b {
pk as int
...
}

我想在查询中加入 a 和 b,如下所示:
FROM a
JOIN b on a.fk = b.pk

以下哪个场景会更快?
  • a.fk设置为 b.pk 上的外键- b.pk已编入索引
  • a.fk设置为 b.pk 上的外键- b.pk未编入索引
  • 表之间没有关系 - b.pk已编入索引
  • 表之间没有关系 - b.pk未编入索引

  • 额外的问题 - 这些场景中的每一个会快多少/慢多少?

    如果你能用引用来支持你的答案,那就太棒了。谢谢!

    最佳答案

    最佳实践

  • 外键是一个 关系完整性工具,而不是性能工具。您应该始终在 FK 列上创建索引以减少查找。 SQL Server 不会自动执行此操作。
  • 如此处所述 Foreign keys boost performance

  • 从逻辑上讲,这给出了以下排名表现明智
  • a.fk设置为 b.pk 上的外键- b.pk已编入索引
  • 表之间没有关系 - b.pk已编入索引
  • a.fk设置为 b.pk 上的外键 - b.pk未编入索引
  • 表之间没有关系 - b.pk未编入索引
  • 关于performance - FK 上的联接是否比没有 FK 的联接更快?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6493993/

    27 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com