Usuário(s) em um Grupo que Não Votaram

Usuário(s) em um Grupo que Ainda Não Votaram

Isso retornará os usuários que pertencem a um grupo nomeado e que não votaram em nenhum tópico aberto. Você precisará fornecer o valor para o parâmetro group_name.

-- [params]
-- string :group_name

WITH voters AS (
SELECT user_id AS voter_id
FROM topic_voting_votes
WHERE archive = FALSE
)

SELECT u.id AS user_id
FROM users u 
JOIN group_users gu ON gu.user_id = u.id 
JOIN groups g ON g.id = gu.group_id
WHERE LOWER(g.name) LIKE LOWER(:group_name)
AND u.id NOT IN (SELECT voter_id FROM voters)

Isso retornará os usuários que pertencem a um grupo nomeado e que não votaram em um tópico específico. Você precisará fornecer o group_name e o topic_id:

-- [params]
-- string :group_name
-- topic_id :topic_id

WITH voters AS (
SELECT user_id AS voter_id
FROM topic_voting_votes tvv
WHERE tvv.topic_id = :topic_id
)

SELECT u.id AS user_id
FROM users u
JOIN group_users gu ON gu.user_id = u.id
JOIN groups g ON g.id = gu.group_id
WHERE LOWER(g.name) LIKE LOWER(:group_name)
AND u.id NOT IN (SELECT voter_id FROM voters)
17 curtidas