mysql将行组合成列

时间:2015-07-02 23:00:22

标签: java mysql

假设我有一张包含以下信息的表格(可能有40多个独特的措施)

表1

id    name    state    Measure       score
1     Joe     CA       work ethic    40
1     Joe     CA       cleanliness   80
1     Joe     CA       helpfulness   70
2     John    TX       work ethic    70
2     John    TX       helpfulness   50
3     Jack    AZ       helpfulness   50

我希望将每个人的度量结合到单独的列中,并将id唯一地添加到一个新表中,如下所示:

表2

id    name    state    workEthicScore    cleanlinessScore    helpfulnessScore
1     Joe     CA       40                80                  70
2     John    TX       70                null                50
3     Jack    AZ       null              null                50

所以,理想情况下,我希望能够创建这个新表而无需手动输入所有不同的Measures。我将如何使用Java和MYSQL进行此操作?我不想使用mysql group_concat,因为我希望将这些作为单独的列而不是组合成一个列。

2 个答案:

答案 0 :(得分:0)

开始构建您的查询:

  SELECT t.id
       , t.name 
       , t.state
       , 0           AS workEthicScore
       , 0           AS cleanlinessScore
       , 0           AS helpfulnessScore
    FROM mytable t
   GROUP
      BY t.id
       , t.name 
       , t.state

要获取返回的score的值,您可以使用执行条件聚合的表达式,并将上面语句中的文字0替换为如下表达式:

       , MAX(IF(t.measure = 'work ethic', t.score,NULL)) AS workEthicScore

measure的其他值重复相同的模式。

要使这样的查询起作用,必须在SQL语句中指定列的数量,列的名称以及用于返回列的值的表达式。这不能在声明中动态完成。

要获得这样的结果,需要两个单独的语句。第二个陈述必须是如上所示的形式。您可以使用单独的语句来获取一些值来帮助您构建该语句,例如

  SELECT m.measure FROM mytable m GROUP BY m.measure 

或者,您可以做一些更高级的事情来生成表达式和别名以包含在第二个语句的SELECT列表中:

  SELECT CONCAT('      , MAX(IF(t.measure='''
           ,REPLACE(m.measure,'''','''''')
           ,''',t.score,NULL) AS `'
           ,m.measure
           ,'`'
         ) AS expr
    FROM mytable m
   GROUP BY m.measure

在一个声明中,无法通过动态列获得这样的结果。

答案 1 :(得分:0)

这是查询 -

mysql> select id, 
              name, 
              state, 
              max(if(measure='work ethic', score, null)) as `work ethic`, 
              max(if(measure='cleanliness',score, null)) cleanliness,        
              max(if(measure='helpfullness',score, null)) helpfullness 
        from tt 
        group by id;
+------+------+-------+------------+-------------+--------------+
| id   | name | state | work ethic | cleanliness | helpfullness |
+------+------+-------+------------+-------------+--------------+
|    1 | Joe  | CA    |         40 |          80 |           70 |
|    2 | Jhon | TX    |         70 |        NULL |           50 |
|    3 | Jack | AZ    |       NULL |        NULL |           50 |
+------+------+-------+------------+-------------+--------------+
3 rows in set (0.00 sec)