XML columns in a geodatabase stored in Oracle

XML is an open standard for defining data elements within documents. To store XML data in an Oracle database, you can use ArcSDE XML columns or native Oracle XML columns.

XML columns in ArcGIS Desktop

XML columns are not completely supported in the geodatabase. Therefore, the following are true:

XML columns in an Oracle DBMS

There are two different types of XML columns you can use: ArcSDE XML or Oracle XML. Which one you use in a dataset you create in your geodatabase is controlled by the XML_COLUMN_STORAGE parameter in the DBTUNE table. By default, this parameter is set to SDE_XML.

NoteNote:

ArcSDE XML data types are used to store collections of metadata documents to support ArcIMS Metadata Services. Therefore, if you use ArcIMS Metadata Services, you must set the XML_COLUMN_STORAGE parameter to SDE_XML.

For information on Oracle XML, consult the Oracle documentation set.

ArcSDE XML columns

ArcSDE XML documents are stored in the database as an Oracle Large Object (LOB). The LOB storage and caching parameters, the block size of the tablespace, and the buffer cache configuration all affect the speed at which LOB data is retrieved, which in turn affects performance when searching.

For ArcSDE XML, there are three ArcSDE geodatabase system tables used to manage XML columns: SDE_XML_COLUMNS, SDE_XML_INDEX_TAGS, and SDE_XML_INDEXES. These tables are owned by the ArcSDE administrator user. ArcSDE also creates two additional tables for each XML column that are used to store and index XML documents: the SDE_XML_DOC<COLUMN_ID> and SDE_XML_IDX_<COLUMN_ID> tables. These tables are owned by the user who owns the business table containing the XML column.

ArcSDE creates the following tables when using ArcSDE XML. These tables are used to store and index XML documents.

CautionCaution:

Do not alter any of these tables using SQL.

SDE_XML_COLUMNS

When you add an ArcSDE XML column to a business table, a row is added to the SDE_XML_COLUMNS table. This table occurs once in each ArcSDE database.

Field name

Field type

Description

Null?

COLUMN_ID

NUMBER

The identifier of the XML column and the primary key for the table

This value is assigned by ArcSDE at the time the ArcSDE XML column is created.

NOT NULL

REGISTRATION_ID

NUMBER

The identifier of the business table containing the ArcSDE XML column and foreign key to the TABLE_REGISTRY system table

NOT NULL

COLUMN_NAME

NVARCHAR2(32)

The name of the ArcSDE XML column in the business table

NOT NULL

INDEX_ID

NUMBER

The identifier of the XPath index associated with the ArcSDE XML column (if one exists) and foreign key to the SDE_XML_INDEXES table

MINIMUM_ID

NUMBER

The value of the initial number used in the ArcSDE XML column of the business table to identify individual XML documents

CONFIG_KEYWORD

NVARCHAR2(32)

The DBTUNE configuration keyword for which the parameters determine how the XML document, the XML XPath index tables, and the text indexes created on those tables are defined in the database

For more information on DBTUNE keywords and their parameters, see What are DBTUNE configuration keywords and parameters? and DBTUNE configuration parameters in Oracle.

XFLAGS

NUMBER

A value indicating whether the original documents in the XML document table are stored compressed or decompressed

By default, documents are compressed; compressed documents provide better performance.

SDE_XML_INDEXES

This table occurs once in each ArcSDE database. It contains one row for each ArcSDE XML column that has an XPath index.

Field name

Field type

Description

Null?

INDEX_ID

NUMBER

The identifier of the XPath index and the primary key for the table

NOT NULL

INDEX_NAME

NVARCHAR2(32)

The name of the XPath index

For XPath indexes associated with an ArcIMS Metadata Service, the name is ims_xml#, where # is the identifier of the ArcSDE XML column in the metadata service business table.

NOT NULL

OWNER

NVARCHAR2(32)

The database user who owns the ArcSDE XML column

For ArcIMS Metadata Services, this is the user specified in the ArcXML configuration file of the service.

NOT NULL

INDEX_TYPE

NUMBER

A value indicating the type of XPath index

With ArcSDE 9.1 and later releases, the value is 2 for the index type SE_XML_INDEX_DEFINITION and 1 for the index type SE_XML_INDEX_TEMPLATE. For XPath indexes associated with an ArcIMS Metadata Service, only the index type SE_XML_INDEX_DEFINITION is supported.

NOT NULL

DESCRIPTION

NVARCHAR2(64)

Text identifying the XPath index

If an index definition file was used to create the index, the index description could be specified at the top of the file.

SDE_XML_INDEX_TAGS

An ArcSDE XML column might optionally have an XPath index, which lets you search the content of a specific XML element or attribute in each document. The definition of which elements and attributes are included in or excluded from each XPath index is recorded in this table.

This table occurs once in each ArcSDE database. It contains one row for each XPath associated with the XPath index of an ArcSDE XML column.

Field name

Field type

Description

Null?

INDEX_ID

NUMBER

The identifier of the XPath index associated with an ArcSDE XML column (if one exists) and foreign key to the SDE_XML_INDEXES table

NOT NULL

TAG_ID

NUMBER

The identifier of an XPath or tag

NOT NULL

TAG_NAME

NVARCHAR2(1024)

An absolute XPath identifying an XML element or attribute that may occur in an XML document

For example, /metadata/mdDateSt identifies an XML element and /metadata/dataIdInfo/tpCat/TopicCatCd/@value identifies an XML attribute.

These XPaths must not contain asterisks (*) to refer to a group of XML elements or attributes—each element or attribute is matched exactly using the XPaths specified in this table. Elements cannot be named * in a valid XML document.

NOT NULL

DATA_TYPE

NUMBER

A value indicating whether the XML element or attribute is indexed as a number, a varchar, or text

A 1 indicates the content of the tag is indexed as text; a 2 indicates the content of the tag is indexed as a number; a 3 indicates the content of the tag is indexed as a varchar.

NOT NULL

TAG_ALIAS

NUMBER

A number that may be used to identify an XPath

For example, the Z39.50 communication protocol uses numeric codes to refer to content that may be searched.

This column is not used by the ArcIMS Z39.50 Connector.

DESCRIPTION

NVARCHAR2(64)

Text identifying the content that should be contained in the XML element or attribute

IS_EXCLUDED

NUMBER

A value indicating whether the XML element is included in or excluded from the XPath index

0 = XPath is included

1 = XPath is excluded

NOT NULL

SDE_XML_DOC<COLUMN_ID>

The SDE_XML_DOC<COLUMN_ID> table stores the XML document and maintains a full-text index on the content of the XML document. The ArcSDE database contains one of these tables for each ArcSDE XML column. The number in the table name is the ArcSDE XML column identifier. This table contains one row for each XML document stored in the ArcSDE XML column.

Field name

Field type

Description

Null?

SDE_XML_ID

NUMBER

The identifier for an XML document stored in the ArcSDE XML column and primary key for the table

NOT NULL

DOC_PROPERTY

NUMBER

A value indicating whether any conflicts were found when adding the content of an XML document to the XPath index

1 = A conflict was found, for example, when an element is supposed to be indexed numerically but the document contains a string in that element instead.

NULL value = There were no problems indexing the document.

XML_DOC

BLOB

The XML document

NOT NULL

XML_DOC_VAL

BLOB

The content of the entire XML document with all XML tags and other markup removed

A text index is built on this column by default; this index is used to respond to full-text queries. For ArcIMS Metadata Services, this index is used to respond to FULLTEXT requests.

SDE_XML_IDX<COLUMN_ID>

The SDE_XML_IDX<COLUMN_ID> table is created for ArcSDE XML columns that have an XPath text index. This table stores the text or number content for each XPath that is indexed.

The ID number in the table name is the internal registration number for the ArcSDE XML column.

Field name

Field type

Description

Null?

XML_KEY_COLUMN

NUMBER

The identifier for the indexed value and primary key for the table

NOT NULL

SDE_XML_ID

NUMBER

The identifier for the XML document that contains the indexed value

NOT NULL

TAG_ID

NUMBER

The identifier for the tag associated with the XPath index of the ArcSDE XML column, which identifies where in the document the value is stored

NOT NULL

DOUBLE_TAG

FLOAT(126)

The indexed value, when the tag is defined as DOUBLE in the XPath index definition

STRING_TAG

NVARCHAR2(256)

The indexed value, when the tag is defined as VARCHAR in the XPath index definition

TEXT_TAG

CLOB

The indexed value, when the tag is defined as STRING in the XPath index definition

The following is a diagram of a table with an ArcSDE XML column and the system tables used to track it. Dashed lines indicate implicit relationships; a solid line denotes explicitly defined relationships between tables.

Sites business table and system tables to support ArcSDE XML columns in Oracle

XML columns in an XML document

You cannot export a table containing an XML column to an XML workspace document. You can export it to an XML recordset document, but there is nothing within the document to distinguish the column as XML.

Related Topics


11/18/2013