如何对不熟悉的行进行分组?

时间:2015-08-01 01:09:50

标签: mysql sql database charts

我的数据如下:http://sqlfiddle.com/#!2/1266b2/1

但我希望它看起来像:

+------------+------+---+
| 2015-01-01 | walk | 1 |
| 2015-01-01 | run  | 0 |
| 2015-01-01 | bike | 0 |
| 2015-01-02 | walk | 0 |
| 2015-01-02 | run  | 0 |
| 2015-01-02 | bike | 0 |
| 2015-01-03 | walk | 0 |
| 2015-01-03 | run  | 1 |
| 2015-01-03 | bike | 0 |
| 2015-01-04 | walk | 0 |
| 2015-01-04 | run  | 0 |
| 2015-01-04 | bike | 0 |
| 2015-01-05 | walk | 0 |
| 2015-01-05 | run  | 1 |
| 2015-01-05 | bike | 0 |
+------------+------+---+

每天都应该收集每个事件响应发生的次数。

  • 日期是从日历表中收集的,因此完全是静态的。
  • 事件名称很多,可能会发生变化。
  • 事件响应为名称和其他上下文规则加入事件。

对于解决这个问题会有很大帮助。至少提供更好的标题(搜索条件)的提示,以便我可以弄清楚如何解决这个问题。

这是用于处理activezoo.com处的图表。对于分析数据的其他方法或方法的任何建议都是非常受欢迎的。

1 个答案:

答案 0 :(得分:5)

听起来您想要每个日期/事件组合,并且您想要计算事件响应数。如果是这样,请在cross joincalendar表之间使用event获取每个组合,然后left joinevent_responses表,并从中计算一列表,所以你只计算匹配。

SELECT calendar.date AS date, events.name AS event, COUNT(event_responses.date) AS count 
FROM events
CROSS JOIN calendar
LEFT JOIN event_responses ON event_responses.event_id = events.id
AND event_responses.date = calendar.date
GROUP BY calendar.date, event
ORDER BY calendar.date, event

http://sqlfiddle.com/#!2/d2560/1