假设我有一张包含以下信息的表格(可能有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,因为我希望将这些作为单独的列而不是组合成一个列。
答案 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)