J’ai quelques idées pour des badges, mais je ne suis pas sûr de savoir comment écrire les requêtes (je ne connais pas assez bien la structure des tables). Les chiffres sont donnés à titre d’exemple. Je les étendrai pour créer d’autres badges.
Quelqu’un a reçu 10 votes sur un seul sujet qu’il a écrit.
Quelqu’un a reçu 20 votes au total sur tous les sujets qu’il a écrits.
Quelqu’un a voté 20 fois.
Est-ce que quelqu’un a déjà des badges comme ceux-ci et souhaite les partager ? Sinon, est-ce que quelqu’un veut essayer d’écrire les requêtes ?
The second query in this topic might do the trick: Badge ideas for Topic Voting. The query grants the badge to users who have cast a single vote, but there is a suggestion at the bottom of the query for how to require more votes to grant the badge.
Thanks @simon. I actually read over that post already but the query didn’t return the results I was expecting. It was the Limit 1 at the end messing me up. After removing that it works perfect for the “Someone voted x times”.
Any idea how to see how many votes a person got on a topic they wrote? Or how many likes they got total?
select
t.user_id,
ucf.value,
count(*)
from
topics t
join user_custom_fields ucf on t.id = cast(ucf.value as int)
where ucf.name = 'votes'
group by ucf.value, t.user_id
order by t.user_id, count(*) desc
The two things I’m trying to get are total votes someone got and the topic that has the most votes for each person. You can see mmontecalvo has 2 topics showing. I’m fairly certain I need to use row_number() to get just the highest post but I don’t know how.
@codinghorror These may be similar to a default badge but none of the defaults are built off topics getting votes.
I think I got it! This will give the topic with the most votes per person that has at least 5 votes on it:
WITH query as (
select
t.user_id,
ucf.value,
count(*) as num,
t.created_at,
row_number() OVER (PARTITION BY t.user_id order by count(*) desc) as rank
from
topics t
join user_custom_fields ucf on t.id = cast(ucf.value as int)
where ucf.name = 'votes'
group by ucf.value, t.user_id, t.created_at
having count(*) >= 5
order by t.user_id)
select user_id, value as topic_id, created_at granted_at
from query where rank = 1
I ended up going with this instead so we could give a badge for each topic someone puts in that gets at least X votes in the correct category:
WITH query as (
select
t.user_id,
ucf.value,
count(*) as num,
t.created_at
from
topics t
join user_custom_fields ucf on t.id = cast(ucf.value as int)
where ucf.name = 'votes' and category_id = (
SELECT id FROM categories WHERE name ilike 'UI Experience Requests'
)
group by ucf.value, t.user_id, t.created_at
having count(*) >= 5
order by t.user_id)
select user_id, value as topic_id, created_at granted_at
from query