1

我在 mysql 中有一个数据集,其中包含多个命名接口的带宽测试结果,以及执行测试的日期和接口的名称。示例数据集如下所示:

|  date  |  testResult  |  interface  |
---------------------------------------
| 12/25  |     32       |    eth0     |
| 12/25  |     21       |    eth0     |
| 12/25  |     25       |    eth0     |
| 12/26  |     30       |    eth0     |
| 12/27  |     33       |    eth0     |
| 12/25  |     12       |    eth1     |
| 12/25  |     16       |    eth1     |
| 12/27  |     3        |    vz0      |
| 12/26  |     120      |    virt1    |

我需要绘制给定日期每个接口的平均结果,所以我目前的解决方案是

SELECT `date`, AVG(`testResult`) as avg, `interface` FROM `tests` WHERE 1=1 
GROUP BY date, interface ORDER BY interface, date

这给了我一个像

|  date  |     avg      |  interface  |
---------------------------------------
| 12/25  |     26       |    eth0     |
| 12/26  |     30       |    eth0     |
| 12/27  |     33       |    eth0     |
| 12/25  |     14       |    eth1     |
| 12/26  |     120      |    virt1    |
| 12/27  |     3        |    vz0      |

我的问题是我需要在日期“加入”(我认为)这些数据,并为当天每个接口的平均值提供一列。结果集中接口的名称和数量不是恒定的,不能硬编码。我理想的结果集如下所示:

|  date  |  avg_eth0    |  avg_eth1   |  avg_virt1   |  avg_vz0   |
-------------------------------------------------------------------
| 12/25  |     26       |      14     |    NULL      |    NULL    |
| 12/26  |     30       |      NULL   |    120       |    NULL    |
| 12/27  |     33       |      NULL   |    NULL      |    3       |

有没有办法执行这个连接,基本上为列的每个唯一值创建一个interface列?

4

2 回答 2

0

如果不知道数据透视表中各列的不同值,就无法以任何形式的 SQL 生成数据透视表查询。

换句话说,您必须对每个界面的一列进行硬编码,如@David Jashi 的答案所示。

但这意味着您需要先了解接口的不同值,然后才能编写 SQL 查询。作为第一步,您可以通过运行查询来非常简单地做到这一点:

SELECT DISTINCT interface FROM `tests`;

然后循环遍历结果,将更多列附加到 SQL 查询中以进行数据透视。

抱歉,SQL 无法查询接口,并且在同一查询中动态添加更多列,因为它遇到数据中的不同值。您需要运行两个查询。

于 2013-09-25T21:16:21.823 回答
0

我建议使用旋转:

select date,
AVG(case when interface='eth0' then avg else 0)) as eth0,
AVG(case when interface='eth0' then avg else 0)) as eth1,
AVG(case when interface='virt1' then avg else 0)) as virt1,
AVG(case when interface='vz0' then avg else 0)) as vz0
from (
SELECT `date`, AVG(`testResult`) as avg, `interface` FROM `tests` WHERE 1=1 
GROUP BY date, interface ORDER BY interface, date) as z group by date
于 2013-09-25T17:56:25.033 回答