Consultando campos e respostas da pesquisa

Estou usando este plugin do Discourse Surveys: GitHub - discourse/discourse-surveys

Ao enviar pesquisas, vejo que botões de rádio, caixas de seleção e menus suspensos parecem ser registrados como NULL no banco de dados. Também parece ter registrado uma resposta duas vezes:

2 curtidas

O valor para

são armazenados em uma tabela separada.

Isso deve te levar aonde você precisa :slight_smile:

-- [params]
-- null int :user_id
-- string :name

SELECT s.name, s.post_id, sf.question, COALESCE(sr.value, sfo.html) AS value, sr.user_id, sr.created_at as responded_at
FROM surveys s
JOIN survey_fields sf ON sf.survey_id = s.id
JOIN survey_responses sr ON sr.survey_field_id = sf.id
LEFT JOIN survey_field_options sfo ON sfo.id = sr.survey_field_option_id
WHERE s.name = :name
AND (:user_id IS NULL OR sr.user_id = :user_id)
ORDER BY sr.user_id

Adicionei uma opção de consulta por usuário (quando deixada vazia, consulta todos os usuários por pesquisa), mas sinta-se à vontade para remover

AND (:user_id IS NULL OR sr.user_id = :user_id)

se você não estiver interessado nisso.

3 curtidas

Ah, eu nem percebi essa tabela extra! Obrigado!

4 curtidas

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.