更新時(shí)間:2021-12-06 09:04:23 來源:動(dòng)力節(jié)點(diǎn) 瀏覽1229次
XML 文檔是嚴(yán)格的文本文件。在數(shù)據(jù)傳輸?shù)纳舷挛闹校陶Z“XML 文檔”是指包含任何形式的結(jié)構(gòu)化數(shù)據(jù)的文件或數(shù)據(jù)流。示例包括電子商務(wù)交易、服務(wù)器 API、數(shù)學(xué)方程式、客戶信息和庫存狀態(tài)。
XML 文檔僅包含標(biāo)記和內(nèi)容。文檔的所有規(guī)則和語義都由處理它們的應(yīng)用程序定義。與 HTML 文檔一樣,XML 文檔可以顯示在 Web 瀏覽器中。在這種情況下,語義通常來自樣式表或資源描述框架 (RDF) 文件。
XML 文檔被稱為“格式良好”或“有效”。格式良好的文檔遵循文檔的所有 XML 規(guī)則——例如,對于每個(gè)開始標(biāo)簽,都有一個(gè)相應(yīng)的結(jié)束標(biāo)簽。有效的 XML 文檔格式良好,但它們也包含文檔類型定義 (DTD),并且它們遵守該定義的約束。例如,以下 XML 文件包含描述文件所有元素的 DTD:
<?xml version = "1.0"?>
<!DOCTYPE ORDERFILE [
<!ELEMENT ORDERFILE (CUSTOMER)*>
<!ELEMENT CUSTOMER (NAME, DATE, ORDERS)>
<!ELEMENT NAME (LAST-NAME, FIRST-NAME)>
<!ELEMENT LAST-NAME (#PCDATA)>
<!ELEMENT FIRST-NAME (#PCDATA)>
<!ELEMENT DATE (#PCDATA)>
<!ELEMENT ORDERS (ITEM)*>
<!ELEMENT ITEM (PRODUCT, NUMBER, (PRICE | CHARGEACCT | SAMPLE))>
<!ELEMENT PRODUCT (#PCDATA)>
<!ELEMENT NUMBER (#PCDATA)>
<!ELEMENT PRICE (#PCDATA)>
<!ELEMENT CHARGEACCT (#PCDATA)>
<!ELEMENT SAMPLE (#PCDATA)>
]>
<ORDERFILE>
<CUSTOMER>
<NAME>
<LAST-NAME>Smith</LAST-NAME>
<FIRST-NAME>Sam</FIRST-NAME>
</NAME>
<DATE>October 15, 2001</DATE>
<ORDERS>
<ITEM>
<PRODUCT>Tomatoes</PRODUCT>
<NUMBER>8</NUMBER>
<PRICE>1.25</PRICE>
</ITEM>
<ITEM>
<PRODUCT>Apples</PRODUCT>
<NUMBER>12</NUMBER>
<PRICE>2.50</PRICE>
</ITEM>
<ITEM>
<PRODUCT>Bananas</PRODUCT>
<NUMBER>6</NUMBER>
<PRICE>.50</PRICE>
</ITEM>
</ORDERS>
</CUSTOMER>
<CUSTOMER>
<NAME>
<LAST-NAME>Snead</LAST-NAME>
<FIRST-NAME>Todd</FIRST-NAME>
</NAME>
<DATE>October 17, 2001</DATE>
<ORDERS>
<ITEM>
<PRODUCT>Slicer/Dicer</PRODUCT>
<NUMBER>1</NUMBER>
<CHARGEACCT>1234-5678-3456-7890</CHARGEACCT>
</ITEM>
</ORDERS>
</CUSTOMER>
</ORDERFILE>
包含并遵守模式而不是 DTD 的文檔被認(rèn)為是“模式有效的”。模式是描述 XML 文檔及其精確結(jié)構(gòu)的文件。當(dāng)通過 xml2fd 實(shí)用程序運(yùn)行時(shí),伴隨模式的 XML 文檔生成最可靠的 FD 和 SELECT 語句,尤其是在模式具有有關(guān)數(shù)據(jù)類型和長度的信息時(shí)。
以下是同一 XML 文檔的模式文件示例。如您所見,它比 DTD 更具描述性。
<?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:annotation>
<xs:documentation>
由 AcuXML(tm) 創(chuàng)建2002/11/12 版本 6.0.0 (2002-11-12)
</xs:documentation>
</xs:annotation>
<xs:element name="TEST-ORDERFILE">
<xs:complexType>
<xs:sequence >
<xs:element maxOccurs="unbounded" ref="CUSTOMER"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="CUSTOMER">
<xs:complexType>
<xs:序列>
<xs:element ref="NAME"/>
<xs:element ref="DATE"/>
<xs:element ref="ORDERS"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="NAME">
<xs:complexType>
<xs:sequence>
<xs:element ref="LAST-NAME"/ >
<xs:element ref="FIRST-NAME"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="ORDERS">
<xs:complexType>
<xs:序列>
<xs:element ref="ITEM" maxOccurs="3"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="ITEM">
<xs:complexType>
<xs:sequence>
<xs:element ref="PRODUCT"/>
<xs:element ref="NUMBER"/>
<xs:element ref="PRICE"/>
<xs:element ref="CHARGEACCT"/>
<xs:element ref="SAMPLE"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="LAST-NAME">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:maxLength value="5" />
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="FIRST-NAME">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:maxLength value="4"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="DATE">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:maxLength value="16"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="PRODUCT">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:maxLength value="12"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="NUMBER">
<xs:simpleType>
<xs:restriction base="xs:integer">
<xs:totalDigits value="2"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="PRICE">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:maxLength value="4"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="CHARGEACCT">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:maxLength value="19"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="SAMPLE">
<xs:simpleType>
<xs:restriction base="xs:integer">
<xs:totalDigits value="1"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
</xs:schema>
ACUCOBOL-GT 應(yīng)用程序可以讀取和寫入任何類型的 XML 數(shù)據(jù)。通常,與您交換數(shù)據(jù)的一方會要求數(shù)據(jù)包含 DTD。有時(shí),他們可能需要一個(gè)用于自己的開發(fā)工作的模式。
使用 AcuXML,您可以指定要生成的 XML 輸出的類型。您使用配置變量 AXML_CREATE_STYLE。如果您希望輸出包含架構(gòu),請將 AXML_CREATE_STYLE 設(shè)置為“架構(gòu)”,然后使用另一個(gè)配置變量來定義架構(gòu)名稱 (AXML_SCHEMA_NAME)。默認(rèn)情況下,每次 ACUCOBOL-GT 生成 XML 輸出時(shí)都會創(chuàng)建一個(gè)模式。為了防止后續(xù)輸出出現(xiàn)這種情況,您可以將第三個(gè)配置變量 AXML_CREATE_SCHEMA 設(shè)置為“false”,然后只包含架構(gòu)文件的名稱。配置變量在配置變量中描述。

初級 202925

初級 203221

初級 202629

初級 203743