Как передать переменную в XPath XQuery в операторе SQL

Сценарий: у меня есть столбец xml в базе данных MSSQL, который я должен анализировать данные XML этой ячейки, используя XQuery .

     Xml content : <AnchoredXml xmlns="urn:schema:Microsoft.Rtc.Management.ScopeFramework.2008" SchemaWriteVersion="2">
  <Key ScopeClass="Global">
    <SchemaId Namespace="urn:schema:Microsoft.Rtc.Management.Deploy.Topology.2008" ElementName="Topology" />
    <AuthorityId Class="Host" InstanceId="00000000-0000-0000-0000-000000000000" />
  </Key>
  <Dictionary Count="1">
    <Item>
      <Key />
      <Value Signature="b1ac04f7-d8f0-4300-86cf-fb2b3383536c">
        <Topology xmlns="urn:schema:Microsoft.Rtc.Management.Deploy.Topology.2008">
          <InternalDomains AllowAllDomains="false" DefaultDomain="ocsqa.com">
            <InternalDomain Name="ocsqa.com" Authoritative="false" AllowSubDomains="false" />
          </InternalDomains>
          <Sites>
            <CentralSite SiteId="1">
              <Name>LyncSite</Name>
              <Location />
            </CentralSite>
          </Sites>
          <Clusters>

Это фрагмент данных содержимого xml в этой одной ячейке.

Я использую запрос ниже, чтобы пройти узлы выше xml:

select @cluster = @Items.query('/DocItemSet/DocItem/Data/*[@SchemaWriteVersion="2"]/*[2]/*[1]/*[2]/*[1]/*[3]') 

Вывод вышеуказанного запроса:

    <p1:Cluster xmlns:p1="urn:schema:Microsoft.Rtc.Management.Deploy.Topology.2008" RequiresReplication="true" RequiresSetup="true" Fqdn="XXXX.ocsqa.com">
  <p1:ClusterId SiteId="1" Number="1" />
  <p1:Machine OrdinalInCluster="1" Fqdn=" XXXX.ocsqa.com">
    <p1:NetInterface InterfaceSide="Primary" InterfaceNumber="1" IPAddress="0.0.0.0" />
    <p1:NetInterface InterfaceSide="External" InterfaceNumber="1" IPAddress="0.0.0.0" />
    <p1:NetInterface InterfaceSide="Pstn" InterfaceNumber="1" IPAddress="0.0.0.0" />
  </p1:Machine>
</p1:Cluster>
<p2:Cluster xmlns:p2="urn:schema:Microsoft.Rtc.Management.Deploy.Topology.2008" RequiresReplication="true" RequiresSetup="true" Fqdn=" XXXX2.ocsqa.com">
  <p2:ClusterId SiteId="1" Number="2" />
  <p2:Machine OrdinalInCluster="1" Fqdn=" XXXX2.ocsqa.com">
    <p2:NetInterface InterfaceSide="Primary" InterfaceNumber="1" IPAddress="0.0.0.0" />
    <p2:NetInterface InterfaceSide="External" InterfaceNumber="1" IPAddress="0.0.0.0" />
    <p2:NetInterface InterfaceSide="Pstn" InterfaceNumber="1" IPAddress="0.0.0.0" />
  </p2:Machine>
</p2:Cluster>
<p3:Cluster xmlns:p3="urn:schema:Microsoft.Rtc.Management.Deploy.Topology.2008" RequiresReplication="true" RequiresSetup="true" Fqdn=" XXXX2.ocsqa.com">
  <p3:ClusterId SiteId="1" Number="3" />
  <p3:Machine OrdinalInCluster="1" Fqdn=" XXXX2.ocsqa.com" />
</p3:Cluster>

Теперь используя запрос, указанный ниже:

select @fqdn = @cluster.value('(./*/*/@Fqdn)[1]','nvarchar(20)') Select @fqdn

Обратите внимание на выделенный индекс № в запросе выше. Используя этот запрос, мы сможем создать первый кластер, доступный в xml, так же, как я хотел поискать и другие кластеры.

Поэтому я хотел использовать этот запрос в цикле while. Для которого я должен передать переменную вместо жестко заданного значения int. Нечто подобное, как показано ниже:

select @fqdn = @cluster.value('(./*/*/@Fqdn)[sql:variable("@test")]','nvarchar(20)')

Я упомянул несколько постов Как использовать XPath с переменной в Oracle XMLTable? http://www.jasonstrate.com/2011/01/xquery-for-the-non-expert-variable-use/

но я получаю ошибку, как показано ниже:

Сообщение 2389, уровень 16, состояние 1, строка 35 XQuery [value()]: для 'value()' требуется одиночный (или пустая последовательность) найденный операнд типа 'xdt:untypedAtomic *' Как передать переменную в XQuery оператора SQL?

1 ответ

Вы должны сообщить SQL Server, что вас интересует только один узел. Добавить [1] в конце.

@cluster.value('(./*/*/@Fqdn)[sql:variable("@test")][1]','nvarchar(20)')
Другие вопросы по тегам