Che ne dici di questo?
SELECT
EventID, EventTime,
AnnouncementValue = t1.EventXML.value('(/Event/Announcement/Value)[1]', 'decimal(10,2)'),
AnnouncementDate = t1.EventXML.value('(/Event/Announcement/Date)[1]', 'date')
FROM
dbo.T1
WHERE
t1.EventXML.exist('/Event/Indicator/Name[text() = "GDP"]') = 1
Troverà tutte le righe in cui si trova il /Event/Indicator/Name
è uguale a GDP
e quindi visualizzerà il <Announcement>/<Value>
e <Announcement>/<Date>
per quelle righe.
Vedi demo SQLFiddle