1

我有一个包含内联 XSD 的 XML 文档(如下所示)。问题是我需要使用从 XSD 推算的属性搜索 XML 内容 - 最好在 LINQ 中(XPATH 也可以)。

因此,在下面的示例中,我希望CATALOG_NAME通过推断 XSDsql:field属性值CATALOG_NAME然后将其与 XML 文档中的真实元素名称进行匹配来查找元素CATALOG_NAMEC00。一旦我有了元素,我就想要它的价值。

我看到了许多 XSD 验证示例和查询 XSD 本身的示例。最后,我正在寻找没有一些手动查找技巧的“合并”功能。

这可能吗?

<return xmlns="urn:schemas-microsoft-com:xml-analysis">
  <root xmlns="urn:schemas-microsoft-com:xml-analysis:rowset" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msxmla="http://schemas.microsoft.com/analysisservices/2003/xmla">
    <xsd:schema targetNamespace="urn:schemas-microsoft-com:xml-analysis:rowset" xmlns:sql="urn:schemas-microsoft-com:xml-sql" elementFormDefault="qualified">
      <xsd:element name="root">
        <xsd:complexType>
          <xsd:sequence minOccurs="0" maxOccurs="unbounded">
            <xsd:element name="row" type="row" />
          </xsd:sequence>
        </xsd:complexType>
      </xsd:element>
      <xsd:simpleType name="uuid">
        <xsd:restriction base="xsd:string">
          <xsd:pattern value="[0-9a-zA-Z]{8}-[0-9a-zA-Z]{4}-[0-9a-zA-Z]{4}-[0-9a-zA-Z]{4}-[0-9a-zA-Z]{12}" />
        </xsd:restriction>
      </xsd:simpleType>
      <xsd:complexType name="xmlDocument">
        <xsd:sequence>
          <xsd:any />
        </xsd:sequence>
      </xsd:complexType>
      <xsd:complexType name="row">
        <xsd:sequence>
          <xsd:element sql:field="CATALOG_NAME" name="CATALOG_NAMEC00" type="xsd:string" minOccurs="0" />
          <xsd:element sql:field="SCHEMA_NAME" name="SCHEMA_NAMEC01" type="xsd:string" minOccurs="0" />
          <xsd:element sql:field="CUBE_NAME" name="CUBE_NAMEC02" type="xsd:string" minOccurs="0" />
          <xsd:element sql:field="DIMENSION_UNIQUE_NAME" name="DIMENSION_UNIQUE_NAMEC03" type="xsd:string" minOccurs="0" />
          <xsd:element sql:field="HIERARCHY_UNIQUE_NAME" name="HIERARCHY_UNIQUE_NAMEC04" type="xsd:string" minOccurs="0" />
        </xsd:sequence>
      </xsd:complexType>
    </xsd:schema>
    <row>
      <CATALOG_NAMEC00>AGS PLANUNG_PA</CATALOG_NAMEC00>
      <CUBE_NAMEC02>Aktionsplan</CUBE_NAMEC02>
      <DIMENSION_UNIQUE_NAMEC03>[Planstand]</DIMENSION_UNIQUE_NAMEC03>
      <HIERARCHY_UNIQUE_NAMEC04>[Planstand].[Planstand]</HIERARCHY_UNIQUE_NAMEC04>
    </row>
  </root>
</return>
4

1 回答 1

0

你可以试试这个 XPath:

//*[local-name()=//*:element[@*:field='CATALOG_NAME']/@name]

这是 XPath 2.0,所以我用作*命名空间前缀,但您可以声明命名空间并使用任何您想要的前缀。

于 2013-02-10T22:29:28.127 回答