PostgreSQL返回时间段之间每月最后一天

/*
 * Param One:开始时间
 * Param Two:结束时间
 * 功能 : 返回时间段之间的每月最后一天
 */

drop function if exists getmonths(text,text);
create or replace function getmonths(text,text)
returns setof int as $body$
declare 
	count int := 0;
	r int;
	top date := ($1||'01')::date;
	down date:= ($2||'01')::date;
begin
	if down < top then return next replace(last_day(top),'-','')::int; end if;
	count = extract(month from age(down,top))+extract(year from age(down,top))*12;
	for i in 0..count loop
		select replace(last_day(((top + (i||' month')::interval))::date),'-','')::int into r;
		if r::text::date + 1 >= current_date then 
			r = replace(current_date-1,'-','')::int;
			return next r;
			exit;
		end if;
		return next r;
	end loop;
end $body$ language plpgsql returns null on null input;

select getmonths('201101','201809');

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值