Jeśli chcesz mieć najbliższą datę wcześniej, zrób to w ten sposób:
SELECT year, session_date
FROM calendar_dates
WHERE session_date < '$date_string'
ORDER BY session_date DESC
LIMIT 1;
Najbliższa data po używa podobnej logiki.
Dla najbliższych po obu stronach:
SELECT year, session_date
FROM calendar_dates
ORDER BY abs(session_date - date '$date_string')
LIMIT 1;