Mysql - 如何使用开始日期和持续时间计算结束日期

时间:2014-05-08 03:53:52

标签: mysql datetime

在查询中,在BU_START_DATE和BU_DURATION的帮助下,我想计算END_DATE。其中持续时间以月为单位表示。 假设BU_START_DATE是2014-05-23T13:10:01.515,BU_DURATION是2,END_DATE应该计算为2014-07-23T13:10:01.515

SELECT A.PROJECT_ID,A.PROJECT_BASIC_INFORMATION_ID,B.VALUE AS BU_START_DATE,C.VALUE AS BU_DURATION
FROM 
PROJECT_BASIC_INFORMATION A,
CUSTOM_ATTRIBUTES_VALUES B,
CUSTOM_ATTRIBUTES_VALUES C
WHERE 
A.TENANT_ID = '100' AND
B.MAP_ID = (SELECT MST_ATTRIBUTE_ID FROM `MST_TENANT_CUSTOM_ATTRIBUTES` 
WHERE LABEL='Budget Project Savings Start Date' AND 
TENANT_ID='100')

AND
C.MAP_ID = (SELECT MST_ATTRIBUTE_ID FROM `MST_TENANT_CUSTOM_ATTRIBUTES` 
WHERE LABEL='Budget Savings Duration' AND 
TENANT_ID='100')

GROUP BY A.PROJECT_BASIC_INFORMATION_ID ORDER BY A.PROJECT_ID;

感谢。

1 个答案:

答案 0 :(得分:1)

使用mysql date_add()来完成这个任务。

mysql> select date_add('2014-05-23T13:10:01.515', INTERVAL 2 month);
+-------------------------------------------------------+
| date_add('2014-05-23T13:10:01.515', INTERVAL 2 month) |
+-------------------------------------------------------+
| 2014-07-23 13:10:01.515000                            |
+-------------------------------------------------------+

所以在查询中只需添加

date_add(BU_START_DATE, INTERVAL BU_DURATION month) as END_DATE