DBMS_XMLQUERY
provides database-to-XMLType
functionality. Whenever possible, use DBMS_XMLGEN
, a built-in package in C, instead of DBMS_XMLQUERY
.
See Also:
Oracle XML DB Developer's GuideThis chapter contains the following topics:
Security Model
Constants
Types
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.
Table 195-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. |
Table 195-2 Types of DBMS_XMLQUERY
Type | Description |
---|---|
|
The type of the query context handle. This is the return type of NEWCONTEXT |
Table 195-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. |
Closes or deallocates a particular query context
PROCEDURE CLOSECONTEXT( ctxHdl IN ctxType);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
Generates and returns the DTD based on the SQL query used to initialize the context. The options are described in the following table.
Syntax | Description |
---|---|
FUNCTION GETDTD(
|
Function that generates the DTD based on the SQL query used to initialize the context. |
PROCEDURE GETDTD(
|
Procedure that generates the DTD based on the SQL query used to initialize the context; specifies the output CLOB for XML document result. |
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
withVer |
(IN) |
Generate the version information? TRUE for yes. |
xDoc |
(IN) |
CLOB into which to write the generated XML document. |
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.
PROCEDURE GETEXCEPTIONCONTENT( ctxHdl IN ctxType, errNo OUT NUMBER, errMsg OUT VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
errNo |
(OUT) |
Error number. |
errMsg |
(OUT) |
Error message. |
Return the number of rows processed for the query.
FUNCTION GETNUMROWSPROCESSED( ctxHdl IN ctxType) RETURN NUMBER;
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
Creates the new context, executes the query, gets the XML back and closes the context. This is a convenience function. The context doesn't have to be explicitly opened or closed. The options are described in the following table.
Syntax | Description |
---|---|
FUNCTION GETXML(
|
This function uses a SQL query in string form. |
FUNCTION GETXML(
|
This function uses a SQL query in CLOB form. |
FUNCTION GETXML(
|
This function generates the XML document based on a SQL query used to initialize the context. |
PROCEDURE GETXML(
|
This procedure generates the XML document based on the SQL query used to initialize the context. |
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
metaType |
(IN) |
XML metadatatype (NONE , DTD , or SCHEMA ). |
sqlQuery |
(IN) |
SQL query. |
xDoc |
(IN) |
CLOB into which to write the generated XML document. |
Creates a query context and it returns the context handle. The options are described in the following table.
Syntax | Description |
---|---|
FUNCTION NEWCONTEXT(
|
Creates a query context from a string. |
FUNCTION NEWCONTEXT(
|
Creates a query context from a CLOB . |
Parameter | IN / OUT | Description |
---|---|---|
sqlQuery |
(IN) |
SQL query, the results of which to convert to XML. |
Specifies whether to throw every original exception raised or to wrap it in an OracleXMLSQLException
.
PROCEDURE PROPAGATEORIGINALEXCEPTION( ctxHdl IN ctxType, flag IN BOOLEAN);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
flag |
(IN) |
TRUE if want to propagate original exception, FALSE to wrap in OracleXMLException. |
Removes the value of a top-level stylesheet parameter. If no stylesheet is registered, this method is not operational.
PROCEDURE REMOVEXSLTPARAM( ctxHdl IN ctxType, name IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
name |
(IN) |
Name of the top level stylesheet parameter. |
Sets a value for a particular bind name.
PROCEDURE SETBINDVALUE( ctxHdl IN ctxType, bindName IN VARCHAR2, bindValue IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
bindName |
(IN) |
Bind name. |
bindValue |
(IN) |
Bind value. |
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.
PROCEDURE SETCOLLIDATTRNAME( ctxHdl IN ctxType, attrName IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
attrName |
(IN) |
Attribute name. |
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.
PROCEDURE SETDATAHEADER( ctxHdl IN ctxType, header IN CLOB := null, tag IN VARCHAR2 := null);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
header |
(IN) |
Header. |
tag |
(IN) |
Tag used to enclose the data header and the rowset. |
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
.
PROCEDURE SETDATEFORMAT( ctxHdl IN ctxType, mask IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
mask |
(IN) |
The date mask. |
Sets the encoding processing instruction in the XML document.
PROCEDURE SETENCODINGTAG( ctxHdl IN ctxType, enc IN VARCHAR2 := DB_ENCODING);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
enc |
(IN) |
The encoding to use. |
Sets the tag to be used to enclose the XML error documents.
PROCEDURE SETERRORTAG( ctxHdl IN ctxType, tag IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
tag |
(IN) |
Tag name. |
Sets the maximum number of rows to be converted to XML. By default, there is no set maximum.
PROCEDURE SETMAXROWS ( ctxHdl IN ctxType, rows IN NUMBER);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
rows |
(IN) |
Maximum number of rows to generate. |
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.
PROCEDURE SETMETAHEADER( ctxHdl IN ctxType, header IN CLOB := null);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
Header |
(IN) |
Header. |
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.
PROCEDURE SETRAISEEXCEPTION( ctxHdl IN ctxType, flag IN BOOLEAN:=true);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
flag |
(IN) |
Throw raised exceptions? TRUE for yes, otherwise FALSE. |
Specifies whether to throw an OracleXMLNoRowsException
when the generated XML document is empty. By default, the exception is not thrown.
PROCEDURE SETRAISENOROWSEXCEPTION( ctxHdl IN ctxType, flag IN BOOLEAN:=false);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
flag |
(IN) |
Throws an OracleXMLNoRowsException if set to TRUE . |
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.
PROCEDURE SETROWIDATTRNAME( ctxHdl IN ctxType, attrName IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
attrName |
(IN) |
Attribute name. |
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.
PROCEDURE SETROWIDATTRVALUE( ctxHdl IN ctxType, colName IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
colName |
(IN) |
Column whose value is to be assigned to the row id attribute. |
Sets the tag to be used to enclose the XML dataset.
PROCEDURE SETROWSETTAG( ctxHdl IN ctxType, tag IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
tag |
(IN) |
Tag name. |
Sets the tag to be used to enclose the XML element corresponding to a db.record
.
PROCEDURE SETROWTAG( ctxHdl IN ctxType, tag IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
tag |
(IN) |
Tag name. |
Sets the number of rows to skip. By default, 0 rows are skipped.
PROCEDURE SETSKIPROWS( ctxHdl IN ctxType, rows IN NUMBER);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
rows |
(IN) |
Maximum 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.
PROCEDURE SETSQLTOXMLNAMEESCAPING( ctxHdl IN ctxType, flag IN BOOLEAN := true);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
flag |
(IN) |
Turn on escaping? TRUE for yes, otherwise FALSE. |
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.
PROCEDURE SETSTYLESHEETHEADER( ctxHdl IN ctxType, uri IN VARCHAR2, type IN VARCHAR2 := 'text/xsl');
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
uri |
(IN) |
Stylesheet URI. |
type |
(IN) |
Stylesheet type; defaults to "text/xsl ". |
Specifies the case of the generated XML tags.
PROCEDURE SETTAGCASE( ctxHdl IN ctxType, tCase IN NUMBER);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
tCase |
(IN) |
The tag's case:
|
Registers a stylesheet to be applied to generated XML. If a stylesheet was already registered, it is replaced by the new one. The options are described in the following table. Passing NULL
for the uri
argument or an empty string for the stylesheet
argument will unset the stylesheet header and type.
Syntax | Description |
---|---|
PROCEDURE SETXSLT(
|
To un-register the stylesheet pass in a null for the uri. |
PROCEDURE SETXSLT(
|
To un-register the stylesheet pass in a null or an empty string for the stylesheet. |
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
uri |
(IN) |
Stylesheet URI. |
stylesheet |
(IN) |
Stylesheet. |
ref |
(IN) |
URL to include, imported and external entities. |
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.
PROCEDURE SETXSLTPARAM( ctxHdl IN ctxType, name IN VARCHAR2, value IN VARCHAR2);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
name |
(IN) |
Name of the top level stylesheet parameter. |
value |
(IN) |
Value to be assigned to the stylesheet parameter. |
Specifies whether to use an XML attribute to indicate NULL
ness, or to do this by omitting the particular entity in the XML document.
PROCEDURE SETNULLATTRIBUTEINDICATOR( ctxHdl IN ctxType, flag IN BOOLEAN);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
flag |
(IN) |
Sets attribute to NULL if TRUE , omits from XML document if FALSE . |
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
.
PROCEDURE USETYPEFORCOLLELEMTAG( ctxHdl IN ctxType, flag IN BOOLEAN := true);
Parameter | IN / OUT | Description |
---|---|---|
ctxHdl |
(IN) |
Context handle. |
flag |
(IN) |
Turn on use of the type name? |