在Postgresql中获取不同日期范围的值

时间:2015-05-13 17:34:57

标签: sql postgresql max date-range

我正在尝试使用另一个表中的日期范围从一个表中获取最大值。我在postgresql数据库上使用SQL。目标是获取添加到具有开始日期和结束日期(按年份和区域)的表格中的日期范围的最大值。我认为这是下面列出的两个步骤。

第一步:我希望使用Table1中日期的两列来创建一个范围。该表包含以下列:

ID (integer(11))
Date1 (varchar(10))
Date2 (varchar(10))
Year (integer)
Area (varchar)

以下是表1中的一些示例数据:

ID   Date1      Date2        Year    Area
101  8/21/2000  11/20/2000   2000    5
102  7/31/2000  10/30/2000   2000    5
103  7/10/2000  10/9/2000    2000    6
104  7/10/2000  10/9/2000    2000    6
105  7/4/2000   10/3/2000    2000    6
106  7/10/2000  10/9/2000    2000    6
107  7/31/2000  10/30/2000   2000    7
108  7/31/2000  10/30/2000   2000    7

第二步:根据Table1中从Date1到Date2的变化日期范围,从Table2中拉出最大值。表2具有以下值:

Date (varchar(12))
Area (varchar(11))
Value (varchar(6))

以下是表2中的一些(非常有限的)样本数据:

Date      Area  Value
8/2/2000    5   72.1
8/25/2000   5   68.4
9/14/2000   5   53.3
7/5/2000    6   47.9
8/1/2000    6   10.2
9/30/2000   6   11.6
8/5/2000    7   35.2
9/1/2000    7   45.4

所以最后我想要一个修改过的Table1,它为日期范围添加了Max_Value(从Table2中提取),看起来像这样:

ID   Date1      Date2       Year    Area    Max_Value
101  8/21/2000  11/20/2000  2000    5       68.4
102  7/31/2000  10/30/2000  2000    5       72.1
103  7/10/2000  10/9/2000   2000    6       11.6
104  7/10/2000  10/9/2000   2000    6       11.6
105  7/4/2000   10/3/2000   2000    6       47.9
106  7/10/2000  10/9/2000   2000    6       11.6
107  7/31/2000  10/30/2000  2000    7       45.4
108  7/31/2000  10/30/2000  2000    7       45.4

感谢您提前提供任何帮助。

1 个答案:

答案 0 :(得分:1)

您可以通过多种方式完成此操作。一种方法是将join与显式聚合一起使用。但是,因为您只需要一列,我认为相关的子查询更容易编码:

select t1.*,
       (select max(t2.value)
        from table2 t2
        where t2.date between t1.date1 and t1.date2
       ) as maxvalue
from table1 t1;