72 похожих чатов

Привет! Хотел бы сразу задать вопрос про индексы. Имею базу на

постгрессе.

И есть вот такая таблица:
CREATE TABLE some_table
(
id BIGINT PRIMARY KEY,
v1 VARCHAR,
v2 VARCHAR,
v3 varchar(21) UNIQUE NOT NULL,
v4 VARCHAR(7),
version BIGINT NOT NULL,
reference_id BIGINT NOT NULL REFERENCES physical_resource_ref,
some_id_ref BIGINT REFERENCES some_anothr_table
);
CREATE INDEX idx_some_table_l
ON some_table (v1);
CREATE INDEX idx_some_table_h
ON some_table (v2);
CREATE INDEX idx_some_table_r
ON some_table (v3);

Как видно, есть три индекса. И вот, допустим я хочу посмотреть план выполнения EXPLAIN SELECT * FROM some_table.
На что получаю:
Seq Scan on some_table (cost=0.00..2.86 rows=86 width=75)

Выходит, что было переборов всего 86 штук, в то время как строк в таблице 105 штук. Или в этом случае происходит INDEX SCAN, а не TABLE SCAN? Т.е перебор идет не по всей таблице, а по бакетам b-дерева?

3 ответов

9 просмотров

rows тянется из статистики, которая может быть несколько устаревшей

> Имею базу на постгрессе. И почему бы не спрашивать в чате по нему? https://t.me/pgsql > Выходит, что было переборов всего 86 штук, в то время как строк в таблице 105 штук Нет, "rows=86" — это не количество "переборов", это оценочное количество возвращаемых этим узлом плана записей. > Или в этом случае происходит INDEX SCAN, а не TABLE SCAN? Т.е перебор идет не по всей таблице, а по бакетам b-дерева? Нет и нет. Что написано (seq.scan), то и будет выполнено.

Если в таблице 100 строку, никакие индексы не нужны и на будут использоваться

Похожие вопросы

Обсуждают сегодня

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
А в каком формате фреймы? Сам формат сейчас придумываешь, или что-то готовое нужно распарсить?
Okhsunrog
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Карта сайта