【发布时间】:2014-12-10 10:41:52
【问题描述】:
我有这个活动表
+--------------+------------------+
| Field | Type |
+--------------+------------------+
| id | int(11) unsigned |
| start_date | timestamp |
| end_date | timestamp |
| ... | |
+--------------+------------------+
我需要一个视图,该视图按 start_date 按 DAY 对这些活动进行分组,但如果 end_date 与 start_date 不在同一天,则视图会再次包含条目,但 start_date 设置为 00:00第二天..(依此类推,根据需要重复多次,直到 start_date 与 end_date 在同一天)
举个例子:
如果活动表包含:
+--------------+----------------------------+----------------------------+
| id | start_date | end_date |
+--------------+----------------------------+----------------------------+
| 1 | 2014-12-02 14:12:00+00 | 2014-12-03 06:45:00+00 |
| 2 | 2014-12-05 15:25:00+00 | 2014-12-05 07:29:00+00 |
+--------------+----------------------------+----------------------------+
视图应包含:
+--------------+----------------------------+----------------------------+
| activity_id | start_date | end_date |
+--------------+----------------------------+----------------------------+
| 1 | 2014-12-02 14:12:00+00 | 2014-12-02 23:59:59+00 |
| 1 | 2014-12-03 00:00:00+00 | 2014-12-03 06:45:00+00 |
| 2 | 2014-12-05 15:25:00+00 | 2014-12-05 07:29:00+00 |
+--------------+----------------------------+----------------------------+
任何帮助将不胜感激!
PS:我正在使用 postgresql
【问题讨论】:
标签: sql database postgresql datetime views