declare @xmlsample xml =
'<root>
<solution>
<solutionnumber>1</solutionnumber>
<productgroup>
<productcategory>
<price>100</price>
<title>Some product</title>
<tax>1</tax>
</productcategory>
</productgroup>
<productcategory2>
<price>200</price>
<title>Some other product</title>
<tax>2</tax>
</productcategory2>
</solution>
<solution>
<solutionnumber>2</solutionnumber>
<productcategory2>
<price>200</price>
<title>Some other product</title>
<tax>2</tax>
</productcategory2>
</solution>
</root>'
SELECT
--T.C.value('(./ancestor::ns1:solutionNumber)[1]', 'varchar(50)') AS solutionnumber ?? no clue
T.C.value('(price)[1]', 'numeric(18,2)') AS price
,T.C.value('(title)[1]', 'varchar(50)') AS title
,T.C.value('(tax)[1]', 'numeric(18,2)') AS tax
FROM @xmlsample.nodes('//node()[title]') AS T(C)
Una rappresentazione dell'XML che sto tentando di distruggere in SQL Server 2008 r2. Trovo il nodo "titolo" e prendo i valori che ho bisogno che sono nella categoria di prodotto. Ora vorrei ottenere il "numero della soluzione", tuttavia questo potrebbe essere uno o più nodi principali sopra il prodotto in quanto vi sono determinati "gruppi" di prodotti.SQL Server .nodes() Nodi padre XML per nome
Come dovrei controllare i nodi padre per nome ("numero di soluzione") finché non lo trovo? Grazie per l'assistenza.
terminologia non corretta da parte mia. Ancora cercando "solutionnumber", comunque. – duffn