相关疑难解决方法(0)

Mysql查询动态地将行转换为列

MySQL可以将列转换为行,动态添加行所需的列数.我认为我的问题可能与数据透视表有关,但我不确定,除了通过给出以下示例,我不知道如何构建这个问题.

给出两个表A和B,看起来像

表A.

+--+-----+----+
|id|order|data|
+--+-----+----+
|1 |1    |P   |
+--+-----+----+
|2 |2    |Q   |
+--+-----+----+
|2 |1    |R   |
+--+-----+----+
|1 |2    |S   |
+--+-----+----+
Run Code Online (Sandbox Code Playgroud)

我想编写一个如下所示的查询:

结果表

+--+-----+-----+
|id|data1|data2|
+--+-----+-----+
|1 |P    |S    |
+--+-----+-----+
|2 |R    |Q    |
+--+-----+-----+
Run Code Online (Sandbox Code Playgroud)

基本上我想将表B中的每一行转换为结果表中的一列.如果在表B中为id = 1添加了一个新条目,那么我希望结果表自动扩展一列以容纳这个额外的数据点.

mysql sql pivot group-by

35
推荐指数
2
解决办法
7万
查看次数

MySQL行到列

任何人都可以帮助我如何使用源表上的行数据作为输出头文件创建查询输出.请参阅下面的插图.

例如

行数据:

+-----------+----------+
| colHeader | value    |
+-----------+----------+
| Header1   | value 1  |
+-----------+----------+
| Header2   | value 2  |
+-----------+----------+
| Header3   | value 3  |
+-----------+----------+
Run Code Online (Sandbox Code Playgroud)

输出:

+-----------+-----------+-----------+
| Header1   | header2   | Header3   |
+-----------+-----------+-----------+
| Value 1   | value 2   | Value 3   |
+-----------+-----------+-----------+
Run Code Online (Sandbox Code Playgroud)

可能吗??

这是我的MySQL脚本.我不认为这是不是正确的方式.我有什么想法可以达到上述输出?

SELECT t1.value AS `Header1`,
       t2.value AS `Header2`,
       t3.value AS `Header3`
  FROM (SELECT * FROM table1 WHERE colHeader='Header1') t1
  JOIN (SELECT * FROM table1 WHERE colHeader='Header2'3) t2 …
Run Code Online (Sandbox Code Playgroud)

mysql row

9
推荐指数
1
解决办法
8284
查看次数

标签 统计

mysql ×2

group-by ×1

pivot ×1

row ×1

sql ×1