xs:override 是 XML Schema 1.1 引入的安全重定义机制,用于在不修改原始 schema 文件的前提下,精确覆盖或增强已引入的类型、元素等定义,需严格匹配名称与类别,且仅支持 XSD 1.1 处理器。

xs:override 是 XML Schema 1.1 中引入的机制,用于安全地替换或增强已有的 schema 定义(比如来自 xs:include 或 xs:import 的类型、元素、属性等),而无需修改原始 schema 文件。它不是“覆盖”语义上的简单覆盖,而是有约束的、显式的重定义,必须严格遵循规则。
下面直接说明怎么用 xs:override 正确覆盖引入的 schema 定义:
确保你的处理器支持 XSD 1.1(如 Xerces-J 2.12+、Saxon EE、libxml2 2.9.12+)。XSD 1.0 不支持 `xs:override`,用了会报错。
你不能在任意位置写 `xs:override`。它必须是 schema 文档的**顶层元素之一**(和 `xs:include`、`xs:import` 同级),且其内容必须只包含对原 schema 中已存在组件的重定义 —— 且名称、种类(element/type/attribute 等)必须完全匹配。
例如,要覆盖 `common.xsd` 中定义的 `xs:complexType name="Person"`:
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns="http://example.com"
targetNamespace="http://example.com"
version="1.1">
<p><!-- 引入原始 schema -->
<xs:include schemaLocation="common.xsd"/></p><p><!-- 覆盖其中的 Person 类型 -->
<xs:override schemaLocation="common.xsd">
<xs:complexType name="Person">
<xs:sequence>
<xs:element name="name" type="xs:string"/>
<xs:element name="age" type="xs:positiveInteger"/>
<xs:element name="email" type="xs:string" minOccurs="0"/>
</xs:sequence>
</xs:complexType>
</xs:override></p><p></xs:schema>如果 `common.xsd` 是通过 `xs:import`(而非 `xs:include`)引入的,它必然有 `namespace`。此时 `xs:override` 的 `schemaLocation` 指向它,但内部重定义必须带上正确的 `targetNamespace`(或用 `xmlns:tns="..."` + `tns:Person`)。
例如 `common.xsd` 声明了 `targetNamespace="http://common.example"`,那么 override 片段应为:
<xs:override schemaLocation="common.xsd">
<xs:complexType name="Person"
xmlns:cm="http://common.example"
targetNamespace="http://common.example">
<!-- ... -->
</xs:complexType>
</xs:override>基本上就这些。xs:override 不复杂但容易忽略版本和匹配精度,用对了就能解耦维护、实现渐进式 schema 升级。
以上就是XSD的xs:override怎么覆盖引入的schema定义的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号