我必须从xml文件导入大约10 000个数据库条目,但使用xsd文件数据结构,如何正确使用xsd文件导入xml数据?我使用PHP。从xsd数据结构解析xml数据?
这是我的XSD架构:
<?xml version="1.0" encoding="UTF-8"?>
<!-- edited with XMLSpy v2010 rel. 3 (x64) (http://www.altova.com) -->
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:element name="shopInformations">
<xs:annotation>
<xs:documentation>All products</xs:documentation>
</xs:annotation>
<xs:complexType>
<xs:sequence minOccurs="0" maxOccurs="unbounded">
<xs:element name="productInformation">
<xs:complexType>
<xs:sequence>
<xs:element name="title" type="xs:string"/>
<xs:element name="author" type="xs:string"/>
<xs:element name="productcode" type="xs:string" minOccurs="0"/>
<xs:element name="content"/>
<xs:element name="sections">
<xs:complexType>
<xs:sequence maxOccurs="unbounded">
<xs:element name="section">
<xs:complexType>
<xs:sequence>
<xs:element name="title"/>
</xs:sequence>
<xs:attribute name="id" type="xs:string" use="required"/>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:sequence>
<xs:attribute name="type" use="required">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="public"/>
<xs:enumeration value="reseller"/>
</xs:restriction>
</xs:simpleType>
</xs:attribute>
<xs:attribute name="version" type="xs:string" use="required"/>
<xs:attribute name="lang" use="required">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="en"/>
<xs:enumeration value="es"/>
</xs:restriction>
</xs:simpleType>
</xs:attribute>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
我的xml文件有450MB左右,我无法打开它...
方式过于宽泛,而不是一个的片段代码在眼前!我猜你可以使用'DOMDocument'并遍历节点,但是没有看到数据,没有人能够真正提供答案。 – RamRaider
你可以添加你当前拥有的任何代码吗?不是每个人都会为你写代码。 –
@NigelRen我现在添加了xsd示例,并尝试使用DOMDocument,但是我找不到使用xsd作为xml导入映射的方式... – nowilius