Można to zrobić na kilka sposobów, jednym z nich jest użycie ROW_NUMBER tak:
SELECT id, type, date
FROM
(
SELECT tb1.id, tb1.type, tb1.Date,
ROW_NUMBER() OVER (PARTITION BY tb1.id ORDER BY tb1.Date DESC) AS RowNo
FROM Table tb1
WHERE tb1.type IN ('A','B')
) x
WHERE x.RowNo = 1
Spowoduje to zwrócenie wiersza dla każdego odrębnego identyfikatora wartość, która ma najnowszą datę.