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

Всем привет, прошу помощи - уже третий день мучаюсь. Есть такой

запрос (максимально упрощен, в реале там больше условий) - https://pastebin.com/qW5gVdNV
Проблема в том что он выполняется довольно долго (10 секунд при количестве записей около 4 миллионов)

Но если поменять 8 строчку с COALESCE(click_sub1, conversion_sub1) AS sub1 на click_sub1 AS sub1 то запрос выполняется уже около секунды.
Я так понимаю что это происходит из-за того что в случае с coalesce запрос не использует индекс поля sub1 (индекс есть, я создавал)

Вот EXPLAIN с оригинальной 8ой строчкой - https://pastebin.com/83nQN0dF

EXPLAIN c `click_sub1 AS sub1` - https://pastebin.com/xHtHnhdb

Подскажите пожалуйста как исправить запрос так чтобы он начал работать шустрее?

4 ответов

5 просмотров

Напиши функциональный индекс на значение COALESCE(click_sub1, conversion_sub1)

Обсуждать производительность "похожего" запроса бессмысленно.

1. Это vanilla PostgreSQL (тогда есть https://t.me/pgsql ) ? Или fork? Или что-то "левое", но сильно похожее? 2. Простые EXPLAIN-ы практически бесполезны для анализа.

Могу тебе лишь порекомендовать "уплощить" запрос, написать его без подзапросов во FROM, это позволить хотя бы осозновать (тебе в первую очередь) что и откуда запрос выбирает.

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

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

Сonst magicTgHTML = (text, entities) => { let processedText = text; let offsetShift = 0; entities.forEach(entity => { const { offset, length, type, url, ...
Андрей
1
t.me/<username> и tg://user?id=<id> отваливаются по понятным причинам
Denis 🐍|👑 | darling! 🥰
7
Кстати, раз про скачивание файлов разговор зашел) Сделал бота для себя (транскрибирующего и суммаризирующего встречи) но не ожидал что за 2 месяца 10к пользователей набежит😅...
Andrey Obolenskiy
8
👋🏻3дpaвcтвуйтe 👋🏻 Ищeм 3aинтepecoвaнныx в дoxoде в cфepe cryрtо!!📈 Oбучeниe Бecплaтнoe!💻 Peзультaт ужe в пepвый дeнь oбучeния!! Moжнo удeлять 1-2 чaca в дeнь!! 3aинтepecoвa...
Рустам Вв
4
коллеги привет. уже второй день бьемся об заклад с одной ошибкой, может вы сталкивались с таки странным поведением? есть тестовый сервер, на который паблишим релизную версию W...
Magzhan
11
Гайз, кто-нибудь пробовал запустить probe-rs под камень, которого нет в probe-rs? Мб есть какой-нибудь пример у кого... Через target-gen попробовал сгенерировать chip-descript...
Максим Смирнов
2
А если без шуток, на чем десктоп сейчас пишут кроссплатформенный (ну чтобы с минимальным допиливанием под каждую платформу) и чтобы хорошая производительность софта была. Толь...
🐈
9
Кстати, эти скоты когда у тебя истекает оплата облака, через пару недель после этого, типа стирают из облака твои файлы. И надо закачивать все повторно когда оплатишь доступ. ...
🐈
2
Слушайте, а при создании навигации на Tailor рили нельзя определять активный пункт навигации, как в Static Pages?
Pavel Lautsevich
11
зачем же переименовывать ? чтобы кол-во участников возросло или вдруг IBM от этого снова на свифте начнет кодить ? Я не понимаю что страшного в том что свифт гавно, если это т...
Oleh Nerzh
10
Карта сайта