xXRustamXx
@xXRustamXx

Как получить общее количество не прочитанных сообщений для диалога?

Схема диалогов

5f35a0fd195ac396656120.png

Я написал sql запрос:
SELECT du.* FROM (
    SELECT
        DISTINCT ON(du."dialogId") du."dialogId", 
        SUBSTRING(dm."message", 1, 60), 
        du."joinedDateTime",
        users."avatarUrl",
        users.username
    FROM dialogs_users du
    LEFT JOIN dialogs_messages dm ON dm."dialogId" = du."dialogId"
    LEFT JOIN users on users.id = dm."senderUserId"
    WHERE 
        du."userId" = '69e56a68-edbd-4f8b-8ccd-cb8031c5c865'
        AND
        dm.id NOT IN (
            SELECT dmd."messageId" FROM dialogs_messages_deleted dmd
            WHERE dmd."userId" = '69e56a68-edbd-4f8b-8ccd-cb8031c5c865'
        )
    ORDER BY du."dialogId", dm."message" DESC
) du
ORDER BY du."joinedDateTime" DESC;

который полностью удовлетворял, но появилась необходимость отображать в диалогах количество непрочитанных сообщений и тут я встрял... я пробовал делать Inner join с таблицей dialogs_messages, но тогда вышеописанный DISTINCT ON сходит на нет. Подскажите пожалуйста - как можно решить эту задачу?
  • Вопрос задан
  • 69 просмотров
Решения вопроса 1
@alexalexes
У вас в итоговой выборке есть dialogId. С помощью него делаете подзапрос в select-e, чтобы получить единственное значение.
SELECT du.*, (
    SELECT COUNT(dm."receiverRead") "unreadMessages"
    FROM dialogs_messages dm
    WHERE 
        dm."dialogId" = du."dialogId" 
        AND dm."receiverRead" = false
        AND dm."senderUserId" NOT IN ('69e56a68-edbd-4f8b-8ccd-cb8031c5c865')
        AND dm.id NOT IN (
            SELECT dmd."messageId" FROM dialogs_messages_deleted dmd
            WHERE dmd."userId" = '69e56a68-edbd-4f8b-8ccd-cb8031c5c865'
        )
    GROUP BY dm."receiverRead"
) 
FROM (
    SELECT
        DISTINCT ON (du."dialogId") du."dialogId", 
        SUBSTRING(dm."message", 1, 60), 
        du."joinedDateTime",
        users."avatarUrl",
        users.username
    FROM dialogs_users du
    LEFT JOIN dialogs_messages dm ON dm."dialogId" = du."dialogId"
    LEFT JOIN users on users.id = dm."senderUserId"
    WHERE 
        du."userId" = '69e56a68-edbd-4f8b-8ccd-cb8031c5c865'
        AND dm.id NOT IN (
            SELECT dmd."messageId" FROM dialogs_messages_deleted dmd
            WHERE dmd."userId" = '69e56a68-edbd-4f8b-8ccd-cb8031c5c865'
        )
    ORDER BY du."dialogId", dm."message" DESC
) du
ORDER BY du."joinedDateTime" DESC;
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
25 апр. 2024, в 12:20
15000 руб./за проект
25 апр. 2024, в 12:08
300 руб./за проект
25 апр. 2024, в 11:49
25000 руб./за проект