#sql-server #xml #sqlxml
#sql-сервер #xml #sqlxml
Вопрос:
У меня есть столбец в таблице с типом данных XML. mycolumn имеет следующее значение
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www
.w3.org/2001/XMLSchema"
xmlns:ns1="http://http://localhost/test/">
<SOAP-ENV:Body>
<ns1:IDResults>
<NCNL>
<Value>123</Value>
</NCNL>
</ns1:IDResults>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
select mycolumn.query('./Envelope/Body')
Мой приведенный выше оператор select ничего не возвращает.
Нужно ли указывать SOAP-ENV:
префикс, если да, то как мне его указать?
Заранее спасибо.
Ответ №1:
Фактический запрос зависит от того, что вы хотите получить, но в основном вы должны указать пространство имен в своем запросе, например:
;with xmlnamespaces ('http://schemas.xmlsoap.org/soap/envelope/' as [SOAP-ENV])
select @data.query('SOAP-ENV:Envelope/SOAP-ENV:Body/*')
Комментарии:
1. Большое вам спасибо за ответ. Он работает, используя ваше предложение.