Проверка XML на XSD завершается неудачно в Oracle, но проверяется в XMLSpy - PullRequest
0 голосов
/ 09 февраля 2011

XSD зарегистрирован в оракуле. Использование XMLTYPE.schemavalidate для проверки XML по зарегистрированному XSD. API выдает ошибку, поскольку «LSX-00295: элемент поля« элемент »не является простым типом». Но тот же XML-файл с тем же XSD хорошо проверяется в Altova XMLSpy. Каким-то образом оракул дает ошибку сложного типа.

Анонимный скрипт, как показано ниже:

declare
lxml  XMLTYPE;
l_err varchar2(4000);
l_transformxml CLOB:='<?xml version="1.0" encoding="UTF-8"?>
<tdvpf:products numproducts="2" xsi:schemaLocation="http://www.techdata.com/vpf VendorPriceFileTemplate_Volume.xsd" xmlns:tdvpf="http://www.techdata.com/vpf" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <product>
        <base>
            <distributorsku numitems="1">
                <item index="2">a</item>
            </distributorsku>
            <vendor numitems="1">
                <item index="2">a</item>
            </vendor>
            <vendorpartnumber numitems="1">
                <item index="2">a</item>
            </vendorpartnumber>
            <endusertype numitems="1">
                <item index="2">Government</item>
            </endusertype>
            <endusersubtype numitems="1">
                <item index="2">a</item>
            </endusersubtype>
            <vendorproductgroup numitems="1">
                <item index="2">a</item>
            </vendorproductgroup>
            <productname numitems="1">
                <item index="2">a</item>
            </productname>
            <productdescription numitems="1">
                <item index="2">a</item>
            </productdescription>
            <cost numitems="1">
                <item index="2">0.0</item>
            </cost>
            <msrp numitems="1">
                <item index="2">0.0</item>
            </msrp>
            <operatingsystem numitems="1">
                <item index="2">Linux</item>
            </operatingsystem>
            <operatingsystemversion numitems="1">
                <item index="2">a</item>
            </operatingsystemversion>
            <platform numitems="1">
                <item index="2">64 bit</item>
            </platform>
            <version numitems="1">
                <item index="2">a</item>
            </version>
            <edition numitems="1">
                <item index="2">a</item>
            </edition>
            <licensetype numitems="1">
                <item index="2">a</item>
            </licensetype>
            <licenseduration numitems="1">
                <item index="2">a</item>
            </licenseduration>
            <packagetype numitems="1">
                <item index="2">Full package product</item>
            </packagetype>
            <mediatype numitems="1">
                <item index="2">a</item>
            </mediatype>
            <maintenancesupporttype numitems="1">
                <item index="2">a</item>
            </maintenancesupporttype>
            <maintenancesupportduration numitems="1">
                <item index="2">a</item>
            </maintenancesupportduration>
            <licenseprogram numitems="1">
                <item index="2">a</item>
            </licenseprogram>
            <language numitems="1">
                <item index="2">a</item>
            </language>
            <productclass numitems="1">
                <item index="2">Applications</item>
            </productclass>
            <mediapartnumber numitems="1">
                <item index="2">a</item>
            </mediapartnumber>
            <requireditems numitems="1">
                <item index="2">a</item>
            </requireditems>
            <seats-qty numitems="1">
                <item index="2">a</item>
            </seats-qty>
            <users-qty numitems="1">
                <item index="2">a</item>
            </users-qty>
            <appliances-qty numitems="1">
                <item index="2">a</item>
            </appliances-qty>
            <devices-qty numitems="1">
                <item index="2">a</item>
            </devices-qty>
            <migrations-qty numitems="1">
                <item index="2">a</item>
            </migrations-qty>
            <mailboxes-qty numitems="1">
                <item index="2">a</item>
            </mailboxes-qty>
            <gigabytes-qty numitems="1">
                <item index="2">a</item>
            </gigabytes-qty>
            <servers-qty numitems="1">
                <item index="2">a</item>
            </servers-qty>
            <workstations-qty numitems="1">
                <item index="2">a</item>
            </workstations-qty>
            <licenses-qty numitems="1">
                <item index="2">a</item>
            </licenses-qty>
            <processors-qty numitems="1">
                <item index="2">a</item>
            </processors-qty>
            <domains-qty numitems="1">
                <item index="2">a</item>
            </domains-qty>
            <nodes-qty numitems="1">
                <item index="2">a</item>
            </nodes-qty>
        </base>
        <licenseprogram>
            <points numitems="1">
                <item index="2">0.0</item>
            </points>
            <minquantity numitems="1">
                <item index="2">0.0</item>
            </minquantity>
            <maxquantity numitems="1">
                <item index="2">0.0</item>
            </maxquantity>
            <volumelevel numitems="1">
                <item index="2">a</item>
            </volumelevel>
            <groupmethod numitems="1">
                <item index="2">ProgramPool</item>
            </groupmethod>
        </licenseprogram>
    </product>
</tdvpf:products>
';
begin
lxml := XMLTYPE (l_transformxml).createschemabasedxml ('VendorPriceFileTemplate_Volume.xsd');
   XMLTYPE.schemavalidate (lxml);

   IF lxml.isschemavalid () = 1
   THEN
      DBMS_OUTPUT.put_line ('XSD validation success');
   END IF;
EXCEPTION
   WHEN OTHERS
   THEN
      l_err := SUBSTR (SQLERRM, 1, 4000);
      DBMS_OUTPUT.put_line ('Error: ' || l_err);
END;

1 Ответ

0 голосов
/ 20 февраля 2011

Очевидно, что схема определяет item как элемент с simpleType , что означает, что она не может содержать атрибуты.

<item index="2">a</item>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...