RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 899825
Accepted
Victor Khovanskiy
Victor Khovanskiy
Asked:2020-10-30 18:42:24 +0000 UTC2020-10-30 18:42:24 +0000 UTC 2020-10-30 18:42:24 +0000 UTC

覆盖索引是否应该包含主键?

  • 772

假设我们有一张桌子A(id int primary key, a varchar(32), b varchar(32), ..., z varchar(32))。

我经常运行一个查询: select count(*) from A where a = :a and b = :b

一个合理的解决方案是在字段上使用覆盖索引,index (a, b)以便没有不必要的数据访问。

  1. 添加到它是否有意义id,是index(a, b, id)吗?
  2. 在使用查询的情况下会有所帮助吗:select count(*) from A where a = :a和select count(*) from A where b = :b. 或者是否有必要在字段上创建单独的索引:index(a)和index(b)?

Postgresql 数据库(虽然我不认为这应该有效果)。

sql
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    Мелкий
    2020-10-30T20:01:57Z2020-10-30T20:01:57Z

    Postgresql 数据库(虽然我不认为这应该有效果)。

    这对于任何性能问题都是至关重要的。

    postgresql 中的索引存储对数据文件中行的物理地址的引用 - TID. 因此,主键的值无关紧要,将主键的字段包含在索引中而不需要它甚至会变得更糟——索引会占用更多的空间,这意味着更多的数据将读取和写入磁盘,shared_buffers 和页面缓存系统将占用更多内存。

    如果使用查询会有所帮助:select count( ) from A where a = :a and select count( ) from A where b = :b

    取决于索引类型。第一个问题的答案是肯定的,对于实际的基础版本可以是抽象的。对于不同类型的索引,必须分别考虑第二个问题的答案。

    • btree是通常的意思,也是create index. 它是一棵树,如果你不能从它的根开始,你就不能正确地搜索这棵树。因此,它btree(a,b)可以加快对 a 的条件的查询,但对于仅在 b 上的条件,它的效率会很低——您将不得不查看整个索引而不是它的一部分。
    • brin- 这种类型的索引不关心参与字段的顺序。brin(a,b)可用于a = ?两者b = ?
    • hash- 好吧,这样更容易,它只是不知道如何使用多列索引。
    • gin/gist有点离题,本身不支持简单类型。btree_gin已经可以使用/ extensions构建btree_gist,但总的来说 gist 和 gin 是单独的文章的好主题。

    还有两个重要的点:

    • 现在只能btree是覆盖索引
    • 即使是封面btree也不能保证表格不会被阅读。相反,它只能保证这张表的某些块可能不必被读取。

    这个看似奇怪的画面是通过 MVCC 机制的实现来解释的。索引仅存储数据和对行的引用,但不存储有关该行的事务可见性的数据。因此,必须检查索引搜索结果的每一行,以查看该行是否对当前事务可见。index only scan实现的本质postgresql是能够跳过事务可见性检查(而不是从表中读取数据块),如果该块具有为visibility map. 该位图autovacuum要么是手动更新vacuum的,因此是需要将 autovacuum 配置为更密集地工作以使 postgresql 正常工作的另一个原因。开箱即用的配置 - 不是为了工作,而是为了在任何地方运行而不会打扰任何人。

    如果可见性图没有说该块对每个人都是可见的,那么数据库需要读取表的这一部分并检查必要的行。对于积极更新和高度相关的数据,拥有覆盖索引可能根本没有意义。


    count但是对于 MVCC 基础来说,这通常是一件非常不方便的事情。对您来说,这是一个简单的数字,用于基础 - 分别检查该行的每个版本,是否对您可见。

    • 4
  2. Michael Mochulsky
    2020-10-30T19:30:37Z2020-10-30T19:30:37Z

    查询中的 id 只有在添加到索引时才会受到伤害。在第二点上,您需要创建单独的索引。

    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5