Example xml used for below queries
Get the value of Field_01 tag
Get the value of field in case you have the field name defined dynamically
Similar in case you need value of value of second row of column_01 in table defined dynamically
declare @xml xml
set @xml = '<Document>
<Main>
<Field_01>Field_01Value</Field_01>
<Field_05>Field_05Value</Field_05>
<TableFields>
<Table_02>
<Row>
<Column_01>Table_02Row_01Col_01Value</Column_01>
<Column_02>Table_02Row_01Col_01Value</Column_02>
</Row>
<Row>
<Column_01>Table_02Row_02Col_01Value</Column_01>
<Column_02>Table_02Row_02Col_02Value</Column_02>
</Row>
</Table_02>
</TableFields>
</Main>
</Document>'
Get the value of Field_01 tag
SELECT @xml.value('(//Field_01/text())[1]', 'nvarchar(max)')
Get the value of field in case you have the field name defined dynamically
declare @field varchar(10)
set @field = 'Field_05'
SELECT @xml.value('(//*[local-name()=sql:variable("@field")]/text())[1]', 'nvarchar(max)')
Similar in case you need value of value of second row of column_01 in table defined dynamically
set @field = 'Table_02'
SELECT @xml.value('(//*[local-name()=sql:variable("@field")]/*/Column_01/text())[2]', 'nvarchar(max)')