Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
13.10.2020, 12:26
|
|||
---|---|---|---|
|
|||
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
Добрый день, коллеги. Есть две таблицы: big_table - более 100 Гб small_table - около 1 Гб Запрос Код: sql 1. 2. 3. 4. 5. 6. 7. 8.
отрабатывает быстро. А если напрямую заджойнить запрос из cte, то он отрабатывает медленно: Код: sql 1. 2. 3. 4. 5.
Появляется Seq Scan on big_table. А в первом случае Index Scan using big_table_small_id_idx Скажите, почему такие метамарфозы? ведь в подзапрос помещен тот же самый запрос из cte... ... |
|||
:
Нравится:
Не нравится:
|
|||
|
13.10.2020, 12:28
|
|||
---|---|---|---|
|
|||
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
комит, крайне странная идея задавать такие вопросы не показав полный план для обоих случаев (причем с analyze) -- Maxim Boguk лучшая поддержка PostgreSQL: dataegret.ru ... |
|||
:
Нравится:
Не нравится:
|
|||
|
13.10.2020, 12:39
|
|||
---|---|---|---|
|
|||
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
я его пересказал. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
13.10.2020, 12:42
|
|||
---|---|---|---|
|
|||
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
Пока мысль такая что cte формирует ограниченный объем данных, точность которого 100% для оптимизатора. А когда запрос пихаем в джоин вместо cte, там данные не точные и оптимизатор выбирает другой план. Обновление статистики тут никак не повлияло. В общем. интересно выслушать мнение более опытных товарищей. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
13.10.2020, 12:55
|
|||
---|---|---|---|
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
комит я его пересказал. войну и мир пойди перескажи. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
13.10.2020, 14:03
|
|||
---|---|---|---|
|
|||
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
комит я его пересказал. "мне Рабинович по телефону напел" -- Maxim Boguk лучшая поддержка PostgreSQL: dataegret.ru ... |
|||
:
Нравится:
Не нравится:
|
|||
|
13.10.2020, 14:06
|
|||
---|---|---|---|
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
комит, Без планов ничего сказать однозначно нельзя, но хрустальный шар подсказывает, что во втором случае условие джойна уходит в подзапрос и отрабатывает до фильтра. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
13.10.2020, 16:39
|
|||
---|---|---|---|
|
|||
Почему запрос вываливается в полное сканирование таблицы а с цте - нет ? |
|||
#18+
комит я его пересказал. на всякий случай если не дошло - в плане перво наперво нужны ЦИФРЫ из которых база считает план а не сам план. Во всяком случае для таких вопросов как у вас... и без цифр и конкретного вида плана - сказать ничего нельзя. Или вы считаете что цифры costs/rows там для красоты? -- Maxim Boguk лучшая поддержка PostgreSQL: dataegret.ru ... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/topic.php?fid=53&mobile=1&tid=1994429]: |
0ms |
get settings: |
8ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
158ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
47ms |
get tp. blocked users: |
2ms |
others: | 13ms |
total: | 261ms |
0 / 0 |