如何在Oracle中执行模式注册和XML验证?


问题陈述
您希望对存储在数据库中的XML数据强制执行XML模式有效性。

解决方案

Oracle 提供了 DBMS_XMLSCHEMA.REGISTERSCHEMA 函数来在 Oracle 数据库中定义 XML 模式。为了验证生成的 xml 数据,我们需要注册模式。注册模式时,格式必须与生成的 xml 格式匹配,或者根据您希望生成 xml 的方式注册模式。

注册提供了两个关键功能。首先,它允许 Oracle 识别可以从中获取模式的外部位置或多个位置。其次,也是最重要的一点,REGISTERSCHEMA 解析模式的语法正确性和完整性。

REGISTERSCHEMA 函数可以从多个位置获取 XML 模式,例如作为 VARCHAR 提供的文本,以及来自 BFILE 或 URI 引用。

以下是执行 xml 模式验证的步骤。

  1. 注册模式

DECLARE   l_schema CLOB; BEGIN l_schema := '<?xml version="1.0"?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"> <!-- definition of simple elements --> <xs:element name="customer_id" type="xs:positiveInteger"/> <xs:element name="email" type="xs:string"/> <xs:element name="name" type="xs:string"/> <xs:element name="order_id" type="xs:positiveInteger"/> <xs:element name="status" type="xs:string"/> <!-- definition of complex elements --> <xs:element name="order"> <xs:complexType> <xs:sequence> <xs:element ref="order_id"/> <xs:element ref="status"/> </xs:sequence> </xs:complexType> </xs:element> <xs:element name="customer"> <xs:complexType> <xs:sequence> <xs:element ref="customer_id"/> <xs:element ref="email"/> <xs:element ref="name"/> <xs:element ref="order" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> </xs:element> </xs:schema>' --In SCHEMAURL , provide the schema name of your choice DBMS_XMLSCHEMA.REGISTERSCHEMA(SCHEMAURL       => 'xml_schema_test.xsd',                                 SCHEMADOC       => l_schema,                                 LOCAL           => TRUE,                                 GENTYPES        => FALSE,                                 GENTABLES       => FALSE,                                 ENABLEHIERARCHY => DBMS_XMLSCHEMA.ENABLE_HIERARCHY_NONE); END;

检查模式是否已创建。

示例

SELECT schema_url FROM user_xml_schemas;

输出

-- Output
xmtest_schema.xsd
  • 如果需要删除模式,请参考以下代码

3) 如果需要删除已创建的模式。

BEGIN
     DBMS_XMLSCHEMA.DELETESCHEMA(
     SCHEMAURL=> 'xml_schema_test.xsd',
     DELETE_OPTION => DBMS_XMLSCHEMA.DELETE_CASCADE_FORCE);
END;
  • 使用 XMLISVALID 函数验证针对已创建模式的 xml。

**XMLISVALID:** XMLISVALID 检查输入 XMLType_instance 是否符合相关的 XML 模式。如果模式有效,则结果为 1,否则为 0。

示例

CREATE TABLE t1 ( xml XMLTYPE); INSERT INTO t1 VALUES ('<?xml version="1.0"?> <customer>    <customer_id>134</customer_id>    <email>taylor.cauchon@internalmail</email>    <name>Taylor Cauchon</name>    <order>       <order_id>921</order_id>       <status>COMPLETE</status>    </order>    <order>       <order_id>485</order_id>       <status>COMPLETE</status>    </order>    <order>       <order_id>1528</order_id>       <status>COMPLETE</status>    </order>    <order>       <order_id>1672</order_id>       <status>COMPLETE</status>    </order>    <order>       <order_id>1319</order_id>       <status>COMPLETE</status>    </order> </customer> '); SELECT XMLISVALID(xml, 'my_schema.xsd') AS is_valid   FROM t1;

更新于:2020年12月4日

浏览量 1K+

启动您的职业生涯

完成课程后获得认证

开始学习
广告