Какво ще кажете за това?
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
Той ще намери всички редове, където /Event/Indicator/Name
е равно на GDP
и след това ще покаже <Announcement>/<Value>
и <Announcement>/<Date>
за тези редове.
Вижте демонстрация на SQLFiddle