Това е лесно за повторно прилагане в PostgreSQL само с помощта на SQL функции, за да подредите това, което вече имате:
create function months_of(interval)
returns int strict immutable language sql as $$
select extract(years from $1)::int * 12 + extract(month from $1)::int
$$;
create function months_between(date, date)
returns int strict immutable language sql as $$
select abs(months_of(age($1, $2)))
$$;
И сега select months_between('1978-06-20', '2011-12-09')
произвежда 401.