我有一个 XML 查询的问题,我已经咀嚼了一段时间,但我无法克服它。我有:
- 创建了指向 ASMX Web 服务的共享 XML 数据源。
- 尝试使用 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>
标签有关。