200 DBMS_XMLQUERY
DBMS_XMLQUERY provides database-to-XMLType functionality. 
               
Note:
With Oracle Database 18.1 Release, the DBMS_XMLQUERY package is deprecated. Use DBMS_XMLGEN instead.
                  
The DBMS_XMLQUERY package has been replaced with improved technology. While Oracle recommends you not to begin development using DBMS_XMLQUERY, Oracle continues to support DBMS_XMLQUERY for reasons of backward compatibility. Your existing applications using DBMS_XMLQUERY will continue to work.
                  
See Also:
For more information, see DBMS_XMLGEN.
This chapter contains the following topics:
200.1 DBMS_XMLQUERY Security Model
Owned by XDB, the DBMS_XMLQUERY package must be created by SYS or XDB. The EXECUTE privilege is granted to PUBLIC.
                  
Subprograms in this package are executed using the privileges of the current user.
200.2 DBMS_XMLQUERY Constants
The DBMS_XMLQUERY package includes several constants to use when specifying parameter values. 
                  
These constants are defined in the following table.
Table 200-1 Constants of DBMS_XMLQUERY
| Constant | Description | 
|---|---|
| 
 | Used to signal that the DB character encoding is to be used. | 
| 
 | The tag name for the element enclosing the XML generated from the result set (that is, for most cases the root node tag name) --  | 
| 
 | The default tag to enclose raised errors --  | 
| 
 | The default name for the cardinality attribute of XML elements corresponding to  | 
| 
 | The default tag name for the element corresponding to  | 
| 
 | Default date mask  | 
| 
 | Indicates that all rows are needed in the output. | 
| 
 | Used to specifies that the output should not contain any XML metadata (for example, no DTD). | 
| 
 | Used to specify that the generation of the DTD is desired. | 
| 
 | Used to specify that the generation of the XML Schema is desired. | 
| 
 | Use lower case tag names. | 
| 
 | Use upper case tag names. | 
200.3 Types
The DBMS_XMLQUERY subprograms use the ctxType type. 
                  
Table 200-2 Types of DBMS_XMLQUERY
| Type | Description | 
|---|---|
| 
 | The type of the query context handle. This is the return type of NEWCONTEXT | 
200.4 Summary of DBMS_XMLQUERY Subprograms
This table lists the DBMS_XMLQUERY subprograms and briefly describes them.
Table 200-3 DBMS_XMLQUERY Package Subprograms
| Method | Description | 
|---|---|
| Closes or deallocates a particular query context. | |
| Generates the DTD. | |
| Returns the thrown exception's error code and error message. | |
| Returns the number of rows processed for the query. | |
| Prints the version of the XSU in use. | |
| Generates the XML document. | |
| Creates a query context and it returns the context handle. | |
| Tells the XSU that if an exception is raised, and is being thrown, the XSU should throw the very exception raised; rather then, wrapping it with an  | |
| Removes a particular top-level stylesheet parameter. | |
| Sets a value for a particular bind name. | |
| Sets the name of the id attribute of the collection element's separator tag. | |
| Sets the XML data header. | |
| Sets the format of the generated dates in the XML document. | |
| Sets the encoding processing instruction in the XML document. | |
| Sets the tag to be used to enclose the XML error documents. | |
| Sets the maximum number of rows to be converted to XML. | |
| Sets the XML meta header. | |
| Tells the XSU to throw the raised exceptions. | |
| Tells the XSU to throw or not to throw an  | |
| Sets the name of the id attribute of the row enclosing tag. | |
| Specifies the scalar column whose value is to be assigned to the id attribute of the row enclosing tag. | |
| Sets the tag to be used to enclose the XML dataset. | |
| Sets the tag to be used to enclose the XML element. | |
| Sets the number of rows to skip. | |
| This turns on or off escaping of XML tags in the case that the SQL object name, which is mapped to a XML identifier, is not a valid XML identifier. | |
| Sets the stylesheet header. | |
| Specified the case of the generated XML tags. | |
| Registers a stylesheet to be applied to generated XML. | |
| Sets the value of a top-level stylesheet parameter. | |
| Specifies weather to use an XML attribute to indicate  | |
| Tells the XSU to use the collection element's type name as the collection element tag name. | 
200.4.1 CLOSECONTEXT
This procedure closes or deallocates a particular query context
Syntax
PROCEDURE CLOSECONTEXT( ctxHdl IN ctxType);
Table 200-4 CLOSECONTEXT Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
200.4.2 GETDTD
Generates and returns the DTD based on the SQL query used to initialize the context. The options are described in the following table.
Syntax
Function that generates the DTD based on the SQL query that is used to initialize the context.
FUNCTION GETDTD(
  ctxHdl IN ctxType,
  withVer IN BOOLEAN := false)
RETURN CLOB;Procedure that generates the DTD based on the SQL query that is used to initialize the context. Specifies the output CLOB for XML document result.
                        
PROCEDURE GETDTD(
  ctxHdl IN ctxType,
  xDoc IN CLOB,
  withVer IN BOOLEAN := false);Parameters
Table 200-5 GETDTD Subprogram Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Generate the version information?  | 
| 
 | 
 | 
 | 
200.4.3 GETEXCEPTIONCONTENT
GETEXCEPTIONCONTENT returns the thrown exception's SQL error code and error message through the procedure's OUT parameters. 
                     
This procedure is a work around the JVM functionality that obscures the original exception by its own exception, rendering PL/SQL unable to access the original exception content.
Syntax
PROCEDURE GETEXCEPTIONCONTENT(
  ctxHdl IN ctxType,
  errNo OUT NUMBER,
  errMsg OUT VARCHAR2);
Parameters
Table 200-6 GETEXCEPTIONCONTENT Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Error number. | 
| 
 | 
 | Error message. | 
200.4.4 GETNUMROWSPROCESSED
Return the number of rows processed for the query.
Syntax
FUNCTION GETNUMROWSPROCESSED( ctxHdl IN ctxType) RETURN NUMBER;
Table 200-7 GETNUMROWSPROCESSED Function Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
200.4.5 GETVERSION
The GETVERSION procedure prints the version of the XSU in use.
                     
Syntax
PROCEDURE GETVERSION();
200.4.6 GETXML
GETXML creates the new context, executes the query, gets the XML back and closes the context. This is a convenience function. The context does not need to be explicitly opened or closed.
                     
Syntax
This function uses a SQL query in string form.
FUNCTION GETXML(
  sqlQuery IN VARCHAR2,
  metaType IN NUMBER := NONE)
RETURN CLOB;This function uses a SQL query in CLOB form.
                        
FUNCTION GETXML(
  sqlQuery IN CLOB,
  metaType IN NUMBER := NONE)
RETURN CLOB;This function generates the XML document based on a SQL query used to initialize the context.
FUNCTION GETXML(
  ctxHdl IN ctxType,
  metaType IN NUMBER := NONE)
RETURN CLOB;This procedure generates the XML document based on the SQL query used to initialize the context.
PROCEDURE GETXML(
  ctxHdl IN ctxType,
  xDoc IN CLOB,
  metaType IN NUMBER := NONE);Parameters
Table 200-8 GETXML Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | XML metadatatype ( | 
| 
 | 
 | SQL query. | 
| 
 | 
 | 
 | 
200.4.7 NEWCONTEXT
NEWCONTEXT creates a save context and returns the context handle.
Syntax
FUNCTION NEWCONTEXT(
  sqlQuery IN VARCHAR2)
RETURN ctxType;FUNCTION NEWCONTEXT(
  sqlQuery IN CLOB)
RETURN ctxType;Parameters
Table 200-9 NEWCONTEXT Function Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | SQL query, the results of which to convert to XML. | 
200.4.8 PROPAGATEORIGINALEXCEPTION
The PROPAGATEORIGINALEXCEPTION procedure specifies whether to throw every original exception raised or to wrap it in an OracleXMLSQLException. 
                     
Syntax
PROCEDURE PROPAGATEORIGINALEXCEPTION(
  ctxHdl IN ctxType,
  flag IN BOOLEAN);
Parameters
Table 200-10 PROPAGATEORIGINALEXCEPTION Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | 
 | 
200.4.9 REMOVEXSLTPARAM
This procedure removes the value of a top-level stylesheet parameter. If no stylesheet is registered, this method is not operational.
Syntax
PROCEDURE REMOVEXSLTPARAM( ctxHdl IN ctxType, name IN VARCHAR2);
Table 200-11 REMOVEXSLTPARAM Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Name of the top level stylesheet parameter. | 
200.4.10 SETBINDVALUE
This procedure sets a value for a particular bind name.
Syntax
PROCEDURE SETBINDVALUE( ctxHdl IN ctxType, bindName IN VARCHAR2, bindValue IN VARCHAR2);
Table 200-12 SETBINDVALUE Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Bind name. | 
| 
 | 
 | Bind value. | 
200.4.11 SETCOLLIDATTRNAME
This procedure sets the name of the id attribute of the collection element's separator tag.
Passing NULL or an empty string for the tag causes the row id attribute to be omitted.
                        
Syntax
PROCEDURE SETCOLLIDATTRNAME( ctxHdl IN ctxType, attrName IN VARCHAR2);
Table 200-13 SETCOLLIDATTRNAME Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Attribute name. | 
200.4.12 SETDATAHEADER
This procedure sets the XML data header.
The data header is an XML entity that is appended at the beginning of the query-generated XML entity, the rowset. The two entities are enclosed by the docTag argument. The last data header specified is used. Passing in NULL for the header parameter unsets the data header. 
                        
Syntax
PROCEDURE SETDATAHEADER( ctxHdl IN ctxType, header IN CLOB := null, tag IN VARCHAR2 := null);
Table 200-14 SETDATAHEADER Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Header. | 
| 
 | 
 | Tag used to enclose the data header and the rowset. | 
200.4.13 SETDATEFORMAT
This procedure sets the format of the generated dates in the XML document.
The syntax of the date format pattern, the date mask, should conform to the requirements of the java.text.SimpleDateFormat class. Setting the mask to NULL or an empty string sets the default mask -- DEFAULT_DATE_FORMAT. 
                        
Syntax
PROCEDURE SETDATEFORMAT( ctxHdl IN ctxType, mask IN VARCHAR2);
Table 200-15 SETDATEFORMAT Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | The date mask. | 
200.4.14 SETENCODINGTAG Procedure
This procedure sets the encoding processing instruction in the XML document.
Syntax
PROCEDURE SETENCODINGTAG( ctxHdl IN ctxType, enc IN VARCHAR2 := DB_ENCODING);
Table 200-16 SETENCODINGTAG Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | The encoding to use. | 
200.4.15 SETERRORTAG Procedure
This procedure sets the tag to be used to enclose the XML error documents.
Syntax
PROCEDURE SETERRORTAG( ctxHdl IN ctxType, tag IN VARCHAR2);
Table 200-17 SETERRORTAG Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Tag name. | 
200.4.16 SETMAXROWS Procedure
This procedure sets the maximum number of rows to be converted to XML. By default, there is no set maximum.
Syntax
PROCEDURE SETMAXROWS ( ctxHdl IN ctxType, rows IN NUMBER);
Table 200-18 SETMAXROWS Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Maximum number of rows to generate. | 
200.4.17 SETMETAHEADER Procedure
This procedure sets the XML meta header.
When set, the header is inserted at the beginning of the metadata part (DTD or XMLSchema) of each XML document generated by this object. The last meta header specified is used. Passing in NULL for the header parameter unsets the meta header. 
                        
Syntax
PROCEDURE SETMETAHEADER( ctxHdl IN ctxType, header IN CLOB := null);
Table 200-19 SETMETAHEADER Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Header. | 
200.4.18 SETRAISEEXCEPTION
This procedure specifies whether to throw raised exceptions.
If this call isn't made or if FALSE is passed to the flag argument, the XSU catches the SQL exceptions and generates an XML document from the exception message.
                        
Syntax
PROCEDURE SETRAISEEXCEPTION( ctxHdl IN ctxType, flag IN BOOLEAN:=true);
Table 200-20 SETRAISEEXCEPTION Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Throw raised exceptions?  | 
200.4.19 SETRAISENOROWSEXCEPTION
This procedure specifies whether to throw an OracleXMLNoRowsException when the generated XML document is empty. By default, the exception is not thrown. 
                     
Syntax
PROCEDURE SETRAISENOROWSEXCEPTION( ctxHdl IN ctxType, flag IN BOOLEAN:=false);
Table 200-21 SETRAISENOROWSEXCEPTION Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Throws an  | 
200.4.20 SETROWIDATTRNAME
This procedure sets the name of the id attribute of the row enclosing tag. Passing NULL or an empty string for the tag causes the row id attribute to be omitted. 
                     
Syntax
PROCEDURE SETROWIDATTRNAME( ctxHdl IN ctxType, attrName IN VARCHAR2);
Table 200-22 SETROWIDATTRNAME Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Attribute name. | 
200.4.21 SETROWIDATTRVALUE
This procedure specifies the scalar column whose value is to be assigned to the id attribute of the row enclosing tag.
Passing NULL or an empty string for the colName assigns the row count value (0, 1, 2 and so on) to the row id attribute.
                        
Syntax
PROCEDURE SETROWIDATTRVALUE( ctxHdl IN ctxType, colName IN VARCHAR2);
Table 200-23 SETROWIDATTRVALUE Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Column whose value is to be assigned to the row id attribute. | 
200.4.22 SETROWSETTAG
This procedure sets the tag to be used to enclose the XML dataset.
Syntax
PROCEDURE SETROWSETTAG( ctxHdl IN ctxType, tag IN VARCHAR2);
Table 200-24 SETROWSETTAG Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Tag name. | 
200.4.23 SETROWTAG
This procedure sets the tag to be used to enclose the XML element corresponding to a db.record. 
                     
Syntax
PROCEDURE SETROWTAG( ctxHdl IN ctxType, tag IN VARCHAR2);
Table 200-25 SETROWTAG Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Tag name. | 
200.4.24 SETSKIPROWS
SETSKIPROWS sets the number of rows to skip. By default, 0 rows are skipped. 
                     
Syntax
PROCEDURE SETSKIPROWS( ctxHdl IN ctxType, rows IN NUMBER);
Table 200-26 SETSKIPROWS Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Maximum number of rows to skip. | 
200.4.25 SETSQLTOXMLNAMEESCAPING
This procedure turns on or off escaping of XML tags in the case that the SQL object name, which is mapped to a XML identifier, is not a valid XML identifier.
Syntax
PROCEDURE SETSQLTOXMLNAMEESCAPING( ctxHdl IN ctxType, flag IN BOOLEAN := true);
Table 200-27 SETSQLTOXMLNAMEESCAPING Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Turn on escaping?  | 
200.4.26 SETSTYLESHEETHEADER
SETSTYLESHEETHEADER sets the stylesheet header (the stylesheet processing instructions) in the generated XML document. 
                     
Passing NULL for the uri argument will unset the stylesheet header and the stylesheet type. 
                        
Syntax
PROCEDURE SETSTYLESHEETHEADER( ctxHdl IN ctxType, uri IN VARCHAR2, type IN VARCHAR2 := 'text/xsl');
Table 200-28 SETSTYLESHEETHEADER Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Stylesheet URI. | 
| 
 | 
 | Stylesheet type; defaults to " | 
200.4.27 SETTAGCASE
SETTAGCASE specifies the case of the generated XML tags. 
                     
Syntax
PROCEDURE SETTAGCASE( ctxHdl IN ctxType, tCase IN NUMBER);
Table 200-29 SETTAGCASE Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | The tag's case: 
 | 
200.4.28 SETXSLT
SETXSLT registers a stylesheet to be applied to generated XML. If a stylesheet was already registered, it is replaced by the new one. Passing NULL for the uri argument, or NULL or an empty string for the stylesheet argument, unsets the stylesheet header and type.
                     
Syntax
To unregister the stylesheet, pass in NULL for the URI. 
                        
PROCEDURE SETXSLT(
  ctxHdl IN ctxType,
  uri IN VARCHAR2,
  ref IN VARCHAR2 := null);To unregister the stylesheet pass in NULL or an empty string for the stylesheet.
                        
PROCEDURE SETXSLT(
  ctxHdl IN ctxType,
  stylesheet CLOB,
  ref IN VARCHAR2 := null);Parameters
Table 200-30 SETXSLT Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Stylesheet URI. | 
| 
 | 
 | Stylesheet. | 
| 
 | 
 | URL to include, imported and external entities. | 
200.4.29 SETXSLTPARAM
SETXSLTPARAM sets the value of a top-level stylesheet parameter. 
                     
The parameter value is expected to be a valid XPath expression; the string literal values would therefore have to be quoted explicitly. If no stylesheet is registered, this method is not operational.
Syntax
PROCEDURE SETXSLTPARAM( ctxHdl IN ctxType, name IN VARCHAR2, value IN VARCHAR2);
Table 200-31 SETXSLTPARAM Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Name of the top level stylesheet parameter. | 
| 
 | 
 | Value to be assigned to the stylesheet parameter. | 
200.4.30 USENULLATTRIBUTEINDICATOR
This procedure specifies whether to use an XML attribute to indicate NULLness, or to do this by omitting the particular entity in the XML document.
                     
Syntax
PROCEDURE SETNULLATTRIBUTEINDICATOR( ctxHdl IN ctxType, flag IN BOOLEAN);
Table 200-32 USENULLATTRIBUTEINDICATOR Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Sets attribute to  | 
200.4.31 USETYPEFORCOLLELEMTAG
This procedure specifies whether to use the collection element's type name as its element tag name.
By default, the tag name for elements of a collection is the collection's tag name followed by _item.
                        
Syntax
PROCEDURE USETYPEFORCOLLELEMTAG( ctxHdl IN ctxType, flag IN BOOLEAN := true);
Table 200-33 USETYPEFORCOLLELEMTAG Procedure Parameters
| Parameter | IN / OUT | Description | 
|---|---|---|
| 
 | 
 | Context handle. | 
| 
 | 
 | Turn on use of the type name? |