|
On 29-Jun-2015 14:14 -0600, Gerald Magnuson wrote:
I have a table of week end dates, "most" of them are Saturday,thanks to all who helped me...
so I could just say (date - 6),
but some of my days of week vary, start of year, end of year...
what SQL do I use to return the previous closest Sunday?
(bonus points to help me when I need to start on "01-01-xxxx",
not Sunday)
this (almost) works, except for beginning and end of year:
SELECT idate.idate(enddt) as end_date
, (idate.idate(enddt)-6 days) as start_date
from week_table
;
here is my finished query,
it receives a WeekEnding date, and returns the Previous 52 week start
and end dates...
Select Begin_Date, End_Date
FROM
( SELECT
Case
When DayOfWeek_ISO(idate.idate(FWYMD))
<=DayOfYear(idate.idate(FWYMD))
then Next_Day(idate.idate(FWYMD) - 8 days, 'SUN')
else Last_Day(idate.idate(FWYMD) - 1 Month) + 1 Day
End as Begin_Date
, idate.idate(FWYMD) as End_Date
FROM TIMELIB.FWC
WHERE idate.idate(FWYMD)<= CURRENT_DATE
order by FWYMD DESC
FETCH FIRST 52 ROWS ONLY
) as subSelect
ORDER BY Begin_Date ASC
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2024 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.