This chapter describes how to load XML data into Oracle XML DB with a focus on SQL*Loader.
This chapter contains these topics:
See Also:Chapter 3, "Using Oracle XML DB"
In Oracle9i release 1 (9.0.1) and higher, the Export-Import utility and SQL*Loader support
XMLType as a column type. Starting with Oracle Database 10g, SQL*Loader also supports loading
XMLType tables. You can load
XMLType data with SQL*Loader using either the conventional method or the direct-path method, regardless of how it is stored (structured, unstructured, or binary XML storage).
Note:For structured storage of XML data, if the data involves inheritance (extension or restriction) of XML Schema types, then SQL*Loader does not support direct-path loading.
That is, if an XML schema contains a
complexType element that extends or restricts another
complexType element (the base type), then this results in some SQL types being defined in terms of other SQL types. In this case, direct-path loading is not supported for object-relational storage.
Oracle XML DB Repository information is not exported when user data is exported. This means that neither the resources nor any information are exported.
XML columns are columns declared to be of type
XMLType columns and tables like object-relational columns and tables. All methods described in the following sections for loading LOB data from the primary datafile or from a LOBFILE value also apply to loading
XMLType columns and tables when the
XMLType data is stored as a LOB.
See Also:Oracle Database Utilities
Note:You cannot specify a SQL string for LOB fields. This is true even if you specify
XMLType data can be present in a control file or in a LOB file. In the former case, the LOB file name is present in the control file.
XMLType data can be quite large, SQL*Loader can load LOB data from either a primary datafile (in line with the rest of the data) or from LOB files, independent of how the data is stored (the underlying storage can, for example, still be object-relational).
To load internal LOBs, Binary Large Objects (BLOBs), Character Large Objects (CLOBs), and National Character Large Object (NCLOBs), or
XMLType columns and tables from a primary datafile, use the following standard SQL*Loader formats:
Predetermined size fields
Length-value pair fields
These formats are described in the following sections and in more detail in Oracle Database Utilities.
This is a very fast and conceptually simple format to load LOBs.
Note:Because the LOBs you are loading might not be of equal size, you can use whitespace to pad the LOB data to make the LOBs all of equal length within a particular data field.
This format handles LOBs of different sizes within the same column (datafile field) without problem. However, this added flexibility can affect performance, because SQL*Loader must scan through the data, looking for the delimiter string.
As with single-character delimiters, when you specify string delimiters, you should consider the character set of the datafile. When the character set of the datafile is different than that of the control file, you can specify the delimiters in hexadecimal (that is, hexadecimal string). If the delimiters are specified in hexadecimal notation, then the specification must consist of characters that are valid in the character set of the input datafile. In contrast, if hexadecimal specification is not used, then the delimiter specification is considered to be in the client (that is, the control file) character set. In this case, the delimiter is converted into the datafile character set before SQL*Loader searches for the delimiter in the datafile.
LOB data can be lengthy enough so that it makes sense to load it from a LOBFILE instead of from a primary datafile. In LOBFILEs, LOB data instances are still considered to be in fields (predetermined size, delimited, length-value), but these fields are not organized into records (the concept of a record does not exist within LOBFILEs). Therefore, the processing overhead of dealing with records is avoided. This type of organization of data is ideal for LOB loading.
There is no requirement that a LOB from a LOBFILE fit in memory. SQL*Loader reads LOBFILEs in 64 KB chunks.
In LOBFILEs the data can be in any of the following types of fields, any of which can be used to load XML columns:
A single LOB field into which the entire contents of a file can be read
Predetermined size fields (fixed-length fields)
Delimited fields (that is,
TERMINATED BY or
PRESERVE BLANKS is not applicable to fields read from a LOBFILE.
Length-value pair fields (variable-length fields) .
To load data from this type of field, use the
VARCHAR2 SQL*Loader data types.
You can specify LOBFILEs either statically (you specify the name of the file) or dynamically (you use a FILLER field as the source of the filename). In either case, when the EOF of a LOBFILE is reached, the file is closed and additional attempts to read data from that file produce results equivalent to reading data from an empty field.
You should not specify the same LOBFILE as the source of two different fields. If you do so, then typically, the two fields will read the data independently.
XMLType data can be loaded directly from the control file itself. In this release, SQL*Loader treats
XMLType data like any other scalar type. For example, consider a table containing a
NUMBER column followed by an
XMLType column stored object-relationally. The control file used for this table can contain the value of the
NUMBER column followed by the value of the
SQL*Loader also accommodates
XMLType instances that are very large. In this case you also have the option to load the data from a LOB file.
You can use SQL*Loader to load large amounts of XML data into Oracle Database.
Example 35-1 illustrates how to load
XMLType data into Oracle Database.
This example uses the control file,
load_data.ctl to load
XMLType data into table
foo. The code registers the XML schema,
person.xsd, in Oracle XML DB, and then creates table
foo. You can alternatively create the table within the XML schema registration process.
CREATE TYPE person_t AS OBJECT(name VARCHAR2(100), city VARCHAR2(100));/ BEGIN -- Delete schema if it already exists (else error) DBMS_XMLSCHEMA.deleteSchema('http://www.oracle.com/person.xsd', 4); END;/ BEGIN DBMS_XMLSCHEMA.registerschema('http://www.oracle.com/person.xsd', '<schema xmlns="http://www.w3.org/2001/XMLSchema"' || ' xmlns:per="http://www.oracle.com/person.xsd"' || ' xmlns:xdb="http://xmlns.oracle.com/xdb"' || ' elementFormDefault="qualified"' || ' targetNamespace="http://www.oracle.com/person.xsd">' || ' <element name="person" type="per:persontype"' || ' xdb:SQLType="PERSON_T"/>' || ' <complexType name="persontype" xdb:SQLType="PERSON_T">' || ' <sequence>' || ' <element name="name" type="string" xdb:SQLName="NAME"' || ' xdb:SQLType="VARCHAR2"/>' || ' <element name="city" type="string" xdb:SQLName="CITY"' || ' xdb:SQLType="VARCHAR2"/>' || ' </sequence>' || ' </complexType>' || ' </schema>', TRUE, FALSE, FALSE); END;/ CREATE TABLE foo OF XMLType XMLSCHEMA "http://www.oracle.com/person.xsd" ELEMENT "person";
Here is the content of the control file,
load_data.ctl, for loading
XMLType data using the registered XML schema,
LOAD DATA INFILE * INTO TABLE foo TRUNCATE XMLType(xmldata) FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' ( xmldata ) BEGINDATA <person xmlns="http://www.oracle.com/person.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.oracle.com/person.xsd http://www.oracle.com/person.xsd"> <name> xyz name 2</name> </person>
You can use command
sqlldr to load the XML data into Oracle Database as follows:
If you want direct-path loading, then use the following:
sqlldr load_data.ctl direct=y
load_data.ctl, the data is present in the control file itself, and a record spanned only one line (it is split over several lines here, for printing purposes).
In the following example, the data is present in a separate file,
person.dat, from the control file,
person.dat contains more than one row, and each row spans more than one line. Here is the control file,
LOAD DATA INFILE * INTO TABLE foo TRUNCATE XMLType(xmldata) FIELDS(fill filler CHAR(1), xmldata LOBFILE (CONSTANT person.dat) TERMINATED BY '<!-- end of record -->') BEGINDATA 0 0 0
The three zeroes (
BEGINDATA indicate that three records are present in the data file,
person.dat. Each record is terminated by
<!-- end of record -->. The contents of
person.dat are as follows:
<person xmlns="http://www.oracle.com/person.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.oracle.com/person.xsd http://www.oracle.com/person.xsd"> <name>xyz name 2</name> </person> <!-- end of record --> <person xmlns="http://www.oracle.com/person.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.oracle.com/person.xsd http://www.oracle.com/person.xsd"> <name> xyz name 2</name> </person> <!-- end of record --> <person xmlns="http://www.oracle.com/person.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.oracle.com/person.xsd http://www.oracle.com/person.xsd"> <name>xyz name 2</name> </person> <!-- end of record -->