I have the following code to pull records from a daterange in PostgreSQL, it works as intended. The "end date" is determined by the "date" column from the last record, and the "start date" is calculated by subtracting a 7-day interval from the "end date".
SELECT date
FROM files
WHERE daterange((
(SELECT date FROM files ORDER BY date DESC LIMIT 1) - interval '7 day')::date, -- "start date"
(SELECT date FROM files ORDER BY date DESC LIMIT 1)::date, -- "end date"
'(]') @> date::date
ORDER BY date ASC
I’m trying to rewrite this query using CTEs, so I can replace those subqueries with values such as end_date and start_date. Is this possible using this method or should I look for other alternatives like variables? I’m still learning SQL.
WITH end_date AS
(
SELECT date FROM files ORDER BY date DESC LIMIT 1
),
start_date AS
(
SELECT date FROM end_date - INTERVAL '7 day'
)
SELECT date
FROM files
WHERE daterange(
start_date::date,
end_date::date,
'(]') @> date::date
ORDER BY date ASC
Right now I’m getting the following error:
ERROR: syntax error at or near "-"
LINE 7: SELECT date FROM end_date - INTERVAL '7 day'
3
Answers
I think this is what you want:
You do not need two CTEs, it’s one just fine, which can be joined to filter data.
You even can make it to be a daterange initially in CTE and use it later like this
Here the first CTE is used just to generate some data.
It will get all
file
lines for dates in the last week, excludingfrom_date
and includingto_date
.I hope I’m not repeating anything, but if I understand your problem correctly I think this will work:
Or perhaps even:
Since you have already determined that the CTE has the max date, there is really no need to further bound it with a between, <= or range. You can simply say anything after that date minus 7 days.
The error in your code above is because you want this:
And not this:
You are subtracting from the table, which doesn’t make sense.