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

Подскажите, как организовать выборку В таблице есть столбы account_id и action.

У одного аккаунта может быть несколько экшенов, например, а1, а2, а3.
Как выбрать только те аккаунты, у которых есть а1, но точно нет а2, а3?

5 ответов

26 просмотров

Самое глупое решение в лоб .... select account_Id, array_agg(action) from table group by account_id having not array[a2,a3] && array_agg(action) and a1 <@ array_agg(action)

Vladimir Lepeshko
А почему оно глупое?

первое что в голову приходит )

А почему не сделать "как слышится, так и пишется"? ;) Т.е. что то вроде: SELECT * -- выбрать только те аккаунты, FROM accounts AS a WHERE a.action = 'a1' -- у которых есть а1 AND NOT EXISTS ( -- но (и) точно нет a2 SELECT 1 FROM accounts AS a2 WHERE a2.id = a.id AND a2.action = 'a2' ) AND NOT EXISTS ( -- и точно нет a3 SELECT 1 FROM accounts AS a3 WHERE a3.id = a.id AND a3.action = 'a3' );

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

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

Ребят в СИ можно реализовать ООП?
Николай
32
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
У меня задача: написать брокер сообщений. Очереди и потребители. Очереди поддерживают приоритеты. Очередь отдает сообщения, только обработчикам с соответствующими характеристи...
Aleksandr Filippov
2
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный TFilestream не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
8
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Карта сайта