我正在使用具有以下结构的表(结果)(不要问,我没有构建它)
id | record_type | user_id | answer_id | choice | score | total | email
-------------------------------------------------------------------------------
1 email xxxxxxx 0 userX@site.com
2 answer xxxxxxx aaaaaa A 0
3 answer xxxxxxx bbbbbb A 0
4 answer xxxxxxx cccccc B 10
5 email yyyyyyy 0 userY@site.com
6 answer yyyyyyy aaaaaa A 0
7 answer yyyyyyy bbbbbb A 0
8 answer yyyyyyy cccccc A 0
9 email zzzzzzz 0 userZ@site.com
10 answer zzzzzzz aaaaaa A 0
11 answer zzzzzzz bbbbbb A 0
12 answer zzzzzzz cccccc B 10
这是一项调查,提交调查后正确答案的得分值会发生变化。我已经运行更新以将“正确”答案的得分值设置为 10,现在我需要使用 record_type: email 更新行的总数,以便我们可以联系获胜者。
目标是将第 1,5 和 9 行的总列设置为 10,0 和 10
我在想这样的事情
UPDATE results SET total = SUM(score)
FROM results GROUP BY user_id WHERE user_id = user_id
但这看起来不对,我担心我可能会走错路。