Tôi cần thực hiện chính xác điều này một lúc trước và kết thúc bằng cách sử dụng thực tế là bạn có thể nhân các khoảng với $1
.
postgres=# select interval '1 year' - interval '1 month' * 5;
?column?
----------
7 mons
(1 row)
Vì vậy, điều này sẽ hoạt động:
query = from ch in Child,
join: loc in assoc(ch, :location),
where: ch.birthday <= fragment("(now() AT TIME ZONE ?)::date - interval '1 month' * ?", loc.time_zone, 2)
Repo.all(query)