9

我正在尝试自动化运行某个PLPGSQL日期范围内的函数的过程。
通常我必须运行以下代码,每个函数调用每天生成一个表:

SELECT dhcp.singleday('2012-11-24'::date, '2012-11-25'::date);
SELECT dhcp.singleday('2012-11-25'::date, '2012-11-26'::date);
SELECT dhcp.singleday('2012-11-26'::date, '2012-11-27'::date);
SELECT dhcp.singleday('2012-11-27'::date, '2012-11-28'::date);
SELECT dhcp.singleday('2012-11-28'::date, '2012-11-29'::date);
SELECT dhcp.singleday('2012-11-29'::date, '2012-11-30'::date);
SELECT dhcp.singleday('2012-11-30'::date, '2012-12-01'::date);
SELECT dhcp.singleday('2012-12-01'::date, '2012-12-02'::date);
SELECT dhcp.singleday('2012-12-02'::date, '2012-12-03'::date);
SELECT dhcp.singleday('2012-12-03'::date, '2012-12-04'::date);

有没有一种好方法可以通过简单的循环或函数在任意日期范围内自动化此类事情?

我认为可能很难处理逐月进行的情况,所以我认为最好假设日期范围是一个月。

4

2 回答 2

23

不需要函数:

select dhcp.singleday(a::date, a::date + 1)
from generate_series(
    '2012-11-24'::date,
    '2012-12-03',
    '1 day'
) s(a)

这适用于任何日期范围。不仅是一个月内。

于 2013-01-19T13:05:38.537 回答
8

简单的plpgsql函数:

CREATE OR REPLACE FUNCTION f_machine_gun_sally(date, date)
  RETURNS void AS
$func$
DECLARE
    d date := $1;
BEGIN

LOOP
    PERFORM dhcp.singleday(d, d+1);
    d := d + 1;
    EXIT WHEN d > $2;
END LOOP;

END
$func$ LANGUAGE plpgsql;
  • PERFORM当你不想关心返回值时使用。
  • 您只需将 a 添加integer到 adate以增加。这样,月或年的界限就无关紧要了。
于 2013-01-19T10:36:21.237 回答