Jeśli twój dokument XML zawiera przestrzenie nazw XML, musisz wziąć je pod uwagę w swoich zapytaniach!
Jeśli więc Twój kod XML wygląda jak próbka, potrzebujesz:
-- define the default XML namespace to use
;WITH XMLNAMESPACES(DEFAULT 'bar')
SELECT
x.u.value('Name[1]', 'varchar(100)') as Name
from
@XMLDOC.nodes('/Feed/Product') x(u)
Lub jeśli wolisz mieć wyraźną kontrolę nad tym, której przestrzeni nazw XML użyć (np. jeśli masz wiele), użyj prefiksów przestrzeni nazw XML:
-- define the XML namespace
;WITH XMLNAMESPACES('bar' as b)
SELECT
x.u.value('b:Name[1]', 'varchar(100)') as Name
from
@XMLDOC.nodes('/b:Feed/b:Product') x(u)