SQL计算具有相同sub_id的两个值的百分比。

时间:2016-03-25 02:16:53

标签: php mysql sql dao

我正在开展一个项目,我列出了5个问题,每个问题都有2个解决方案。用户可以对每个问题的一个解决方案进行投票现在我必须计算每个问题最高值的百分比。

例如在问题1中,我在解决方案1上有20票,在解决方案2上有30票,我想得到60%。我知道我必须将每个问题的两个投票值除以100然后再乘以最高的值。

我如何在我的dao(使用sql)中执行此操作?我是否必须在表“解决方案”中创建另一列?

table: solutions
+----------+------------+---------+
|    id    | id_problem |  vote   |
+----------+------------+---------+
|    1     |     1      |    25   |
|    2     |     1      |    10   |
|    3     |     2      |    18   |
|    4     |     2      |    2    |
|    5     |     3      |    6    |
|    6     |     3      |    7    |
|    7     |     4      |    11   |
|    8     |     4      |    4    |
|    9     |     5      |    5    |
|    10    |     5      |    2    |
+----------+------------+---------+

1 个答案:

答案 0 :(得分:2)

试试这个:

select 
    id_problem,
    CONCAT(ROUND(MAX(vote) / SUM(vote), 2) * 100, '%') as Percentage
from solutions
group by id_problem;