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

Добрйы день, коллеги. А кто-нибудь сталкивался с дублями таблиц в

select * FROM pg_statio_user_tables?

8 ответов

19 просмотров
Dmitriy-S Автор вопроса

точно нет и relid одинаковый

Dmitriy S
точно нет и relid одинаковый

Покажите. Казалось бы, тогда там дубли в pg_class. Дело в том, что основа этого view примерно такая: SELECT c.oid AS relid, n.nspname AS schemaname, c.relname, t.relname AS toast_name FROM pg_class AS c LEFT JOIN pg_class AS t ON c.reltoastrelid = t.oid LEFT JOIN pg_namespace AS n ON n.oid = c.relnamespace;

Dmitriy-S Автор вопроса
Yaroslav Schekin
Покажите. Казалось бы, тогда там дубли в pg_class....

SELECT c.oid AS relid, n.nspname AS schemaname, c.relname, pg_stat_get_blocks_fetched(c.oid) - pg_stat_get_blocks_hit(c.oid) AS heap_blks_read, pg_stat_get_blocks_hit(c.oid) AS heap_blks_hit, sum(pg_stat_get_blocks_fetched(i.indexrelid) - pg_stat_get_blocks_hit(i.indexrelid))::bigint AS idx_blks_read, sum(pg_stat_get_blocks_hit(i.indexrelid))::bigint AS idx_blks_hit, pg_stat_get_blocks_fetched(t.oid) - pg_stat_get_blocks_hit(t.oid) AS toast_blks_read, pg_stat_get_blocks_hit(t.oid) AS toast_blks_hit, pg_stat_get_blocks_fetched(x.indexrelid) - pg_stat_get_blocks_hit(x.indexrelid) AS tidx_blks_read, pg_stat_get_blocks_hit(x.indexrelid) AS tidx_blks_hit FROM pg_class c LEFT JOIN pg_index i ON c.oid = i.indrelid LEFT JOIN pg_class t ON c.reltoastrelid = t.oid LEFT JOIN pg_index x ON t.oid = x.indrelid LEFT JOIN pg_namespace n ON n.oid = c.relnamespace WHERE c.relkind = ANY (ARRAY['r'::"char", 't'::"char", 'm'::"char"]) GROUP BY c.oid, n.nspname, c.relname, t.oid, x.indexrelid; Буду смотреть

Dmitriy S
SELECT c.oid AS relid, n.nspname AS schemaname...

Хмм... а из какой это версии? Потому что в v15: CREATE OR REPLACE VIEW pg_catalog.pg_statio_all_tables AS SELECT c.oid AS relid, n.nspname AS schemaname, c.relname, pg_stat_get_blocks_fetched(c.oid) - pg_stat_get_blocks_hit(c.oid) AS heap_blks_read, pg_stat_get_blocks_hit(c.oid) AS heap_blks_hit, i.idx_blks_read, i.idx_blks_hit, pg_stat_get_blocks_fetched(t.oid) - pg_stat_get_blocks_hit(t.oid) AS toast_blks_read, pg_stat_get_blocks_hit(t.oid) AS toast_blks_hit, x.idx_blks_read AS tidx_blks_read, x.idx_blks_hit AS tidx_blks_hit FROM pg_class c LEFT JOIN pg_class t ON c.reltoastrelid = t.oid LEFT JOIN pg_namespace n ON n.oid = c.relnamespace LEFT JOIN LATERAL ( SELECT sum(pg_stat_get_blocks_fetched(pg_index.indexrelid) - pg_stat_get_blocks_hit(pg_index.indexrelid))::bigint AS idx_blks_read, sum(pg_stat_get_blocks_hit(pg_index.indexrelid))::bigint AS idx_blks_hit FROM pg_index WHERE pg_index.indrelid = c.oid) i ON true LEFT JOIN LATERAL ( SELECT sum(pg_stat_get_blocks_fetched(pg_index.indexrelid) - pg_stat_get_blocks_hit(pg_index.indexrelid))::bigint AS idx_blks_read, sum(pg_stat_get_blocks_hit(pg_index.indexrelid))::bigint AS idx_blks_hit FROM pg_index WHERE pg_index.indrelid = t.oid) x ON true WHERE c.relkind = ANY (ARRAY['r'::"char", 't'::"char", 'm'::"char"])

Dmitriy S
14.5 в CloudSQL

А это точно не fork (тогда причём тут PostgreSQL, по большому счёту)? ;)

Yaroslav Schekin
Хмм... а из какой это версии? Потому что в v15: CR...

В ванильном 14 -- тожэ как он говорит, это в 15 переделали на LATERAL JOIN. Впрочем, проблема, скорее всего именно в форке и его переделанном тостере. Несложно заметить, что оно принцыпиально завязано на то, что у toast-таблицы ровно один индэкс.

Dmitriy S
14.5 в CloudSQL

Пинайте поддержку cloudsql -- это явно их баг какой-то (возможно, не тот, что я указал).

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
32
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
25
Книга Юрова В.И пойдёт для обучения?
Botsman
24
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Подскажите пожалуйста, а я могу вот такую штуку использовать? rpc, только реализованное в реббите https://www.rabbitmq.com/tutorials/tutorial-six-php ( или https://habr.com/ru...
Artyom
11
а мы ещё не созрели до того, чтобы создать отдельный чатик про настройку редакторов?
Cheese Syrowiecki
16
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Всем привет! У меня почему-то по-разному отображается TListView в Debug и Release режимах (FireMonkey)! При запуске под Win приложения TListView заливается программо. в Debug ...
Александр COM
8
Ладно, ещё тупого спрошу. Код должен банально вывести значение регистра на консоль, на деле же не выводя ничего, просто оставляя нерабочую консоль (открыта, ничего не написан...
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
25
Парни, спасайте. RAD Studio 12 творит какую-то дичь. У меня есть метод (event), который вызывает другой метод, т.е. он состоит из 1-й строки вызова. Ставлю бряк на event, запу...
Eugene Krasnikov (ᴊɪɴ x)
3
Карта сайта