date_trunc()
पिछले सोमवार . को काटता है . आप अभी भी इनपुट (शनि और सोम के बीच का अंतर) में 2 दिन जोड़कर इसका उपयोग कर सकते हैं, फिर आउटपुट से 2 दिन घटा सकते हैं। पूरी तरह से काम करता है।
यह क्वेरी आपका वांछित आउटपुट बिल्कुल उत्पन्न करती है :
SELECT d::date AS "Calendar_Date"
, EXTRACT('WEEK' FROM d)::int AS "Week_No"
, to_char(d, 'Dy') AS "WeekDay_No"
, base_nr + (rn::int - 1) / 7 AS "Customized_Week_No"
FROM (
SELECT date_trunc('week', feb3) - interval '2 days' AS day1 -- subtract 2 days
, EXTRACT('year' FROM feb3)::int * 100 + 1 AS base_nr
FROM (SELECT timestamp '2015-02-03') input(feb3) -- add 2 days, so Feb 3 (!)
) t, generate_series (day1
, day1 + interval '1 year - 1 day'
, interval '1 day') WITH ORDINALITY AS d(d, rn);
बस संबंधित वर्ष का 3 फरवरी प्रदान करें:timestamp '2015-02-03'
।