1

我有一个 XML 查询的问题,我已经咀嚼了一段时间,但我无法克服它。我有:

  1. 创建了指向 ASMX Web 服务的共享 XML 数据源。
  2. 尝试使用 XML 查询创建数据集。

a) 如果我获取 Web 服务结果并使用 运行 XML 查询<XMLData>,那么我会得到一个结果集。显然查询不包括 Method 或 SoapAction 因为它直接访问<XMLData>.I 确实包括以下内容<ElementPath>outboundMessage/clinicLocationPanel/clinicLocation</ElementPath>.

b)如果我排除<XMLData>并包括 SoapAction 和 Method 并使用通配符,<ElementPath IgnoreNamespaces="true">*</ElementPath>那么我会得到一个结果集。

c) 但是,如果我尝试用 做“b)” <ElementPath>outboundMessage/clinicLocationPanel/clinicLocation</ElementPath>,那么它不会返回任何结果(一堆空行)。

“a)”示例:

<Query xmlns="http://sample.org/pcp">
  <XmlData>
<?xml version="1.0" encoding="UTF-8"?>
<outboundMessage xmlns="http://sample.org/pcp">
  <messageType>ADT</messageType>
  <triggerType>A28</triggerType>
  <outboundGUID>48B30711-4FC4-4A9A-8B73-BCF78EA7E23A</outboundGUID>
  <inmateProfile>
    <patientType/>
    <patientClass/>
    <accountNumber>123456789</accountNumber>
  </inmateProfile>
  <providerPanel>
    <provider>
      <medicalProviderAlias>1115</medicalProviderAlias>
      <medicalProviderID>CERN1948697</medicalProviderID>
      <providerType>PCP</providerType>
    </provider>
    <provider>
      <medicalProviderAlias>27201535</medicalProviderAlias>
      <medicalProviderID>CERN3114945</medicalProviderID>
      <providerType>RN</providerType>
    </provider>
    <provider>
      <medicalProviderAlias>4004132</medicalProviderAlias>
      <medicalProviderID>CERN1618580</medicalProviderID>
      <providerType>DDS</providerType>
    </provider>
  </providerPanel>
  <clinicLocationPanel>
    <clinicLocation>
      <medicalClinicAlias>31821049</medicalClinicAlias>
      <medicalClinicID>31868323</medicalClinicID>
      <clinicType>Nursing</clinicType>
    </clinicLocation>
    <clinicLocation>
      <medicalClinicAlias>31823201</medicalClinicAlias>
      <medicalClinicID>31870163</medicalClinicID>
      <clinicType>Medical</clinicType>
    </clinicLocation>
    <clinicLocation>
      <medicalClinicAlias>31821081</medicalClinicAlias>
      <medicalClinicID>31822493</medicalClinicID>
      <clinicType>Pharmacy</clinicType>
    </clinicLocation>
    <clinicLocation>
      <medicalClinicAlias>31821089</medicalClinicAlias>
      <medicalClinicID>31823145</medicalClinicID>
      <clinicType>Radiology</clinicType>
    </clinicLocation>
    <clinicLocation>
      <medicalClinicAlias>31821097</medicalClinicAlias>
      <medicalClinicID>31823145</medicalClinicID>
      <clinicType>MentalHealth</clinicType>
    </clinicLocation>
    <clinicLocation>
      <medicalClinicAlias>32909551</medicalClinicAlias>
      <medicalClinicID>31821579</medicalClinicID>
      <clinicType>Therapies</clinicType>
    </clinicLocation>
    <clinicLocation>
      <medicalClinicAlias>32909567</medicalClinicAlias>
      <medicalClinicID>31823145</medicalClinicID>
      <clinicType>Specialties</clinicType>
    </clinicLocation>
    <clinicLocation>
      <medicalClinicAlias>32909581</medicalClinicAlias>
      <medicalClinicID>31822109</medicalClinicID>
      <clinicType>Telemed</clinicType>
    </clinicLocation>
  </clinicLocationPanel>
</outboundMessage>
  </XmlData>
<ElementPath>outboundMessage/clinicLocationPanel/clinicLocation</ElementPath>
</Query>

旁注:当我使用 SQL Profiler 时,我看到参数被正确传递,如果从 SQL Profiler 获取相同的查询并执行它,它将返回 XML。我认为我的问题可能与<Method>or<ElementPath>标签有关。

4

0 回答 0