Nie bezpośrednio. Musisz użyć CASE, CAST oznacza, że jest interpretowany jako logiczny przez kod klienta
SELECT
CAST(CASE WHEN expiry < getdate() THEN 1 ELSE 0 END AS bit) AS Expired
FROM
MyTable WHERE (ID = 1)
Inne rozwiązanie, w którym oczekiwany jest jeden lub zero wierszy:
SELECT
CAST(COUNT(*) AS bit) AS Expired
FROM
MyTable
WHERE
ID = 1 AND expiry < getdate()