Oracle® XML Developer's Kit Programmer's Guide 10g Release 2 (10.2) Part Number B14252-01 |
|
|
PDF · Mobi · ePub |
This chapter contains reference information for the XSQL pages framework. "XSQL Configuration File Parameters" describes settings in the XSQL configuration file. Table 27-1 lists the legal built-in actions for XSQL pages.
Table 27-1 Built-In XSQL Elements and Action Handler Classes
XSQL Action Element | Handler Class in oracle.xml.xsql.actions | Purpose |
---|---|---|
<xsql:action> |
XSQLExtensionActionHandler |
Invoke a user-defined action handler, implemented in Java, for executing custom logic and including custom XML data in your XSQL page. |
<xsql:delete-request> |
XSQLDeleteRequestHandler |
Delete an existing row in the database based on the posted XML document supplied in the request. |
<xsql:dml> |
XSQLDMLHandler |
Execute a SQL DML statement or a PL/SQL anonymous block. |
<xsql:if-param> |
XSQLIfParamHandler |
Conditionally include XML content or other XSQL actions. |
<xsql:include-owa> |
XSQLIncludeOWAHandler |
Include the results of a stored procedure that uses the Oracle Web Agent (OWA) packages in the database to generate XML. |
<xsql:include-param> |
XSQLGetParameterHandler |
Include a parameter and its value as an element in the XSQL page. |
<xsql:include-posted-xml> |
XSQLIncludePostedXMLHandler |
Include the XML document that has been posted in the request into the XSQL page. |
<xsql:include-request-params> |
XSQLIncludeRequestHandler |
Include all request parameters as XML elements in the XSQL page. |
<xsql:include-xml> |
XSQLIncludeXMLHandler |
Include arbitrary XML resources at any point in your page by relative or absolute URL. |
<xsql:include-xsql> |
XSQLIncludeXSQLHandler |
Include the results of one XSQL page at any point inside another. |
<xsql:insert-param> |
XSQLInsertParameterHandler |
Insert the XML document contained in the value of a single parameter. |
<xsql:insert-request> |
XSQLInsertRequestHandler |
Insert the XML document or HTML form posted in the request into a table or view. |
<xsql:query> |
XSQLQueryHandler |
Execute an arbitrary SQL statement and include its result in canonical XML format. |
<xsql:ref-cursor-function> |
XSQLRefCursorFunctionHandler |
Include the canonical XML representation of the result set of a cursor returned by a PL/SQL stored function. |
<xsql:set-cookie> |
XSQLSetCookieHandler |
Set an HTTP Cookie. |
<xsql:set-page-param> |
XSQLSetPageParamHandler |
Set an HTTP-Session level parameter. Set a page-level (local) parameter that can be referred to in subsequent SQL statements in the page. |
<xsql:set-session-param> |
XSQLSetSessionParamHandler |
Set an HTTP-Session level parameter. |
<xsql:set-stylesheet-param> |
XSQLStylesheetParameterHandler |
Set the value of a top-level XSLT stylesheet parameter. |
<xsql:update-request> |
XSQLUpdateRequestHandler |
Update an existing row in the database based on the posted XML document supplied in the request. |
You can use the XSQL configuration file to tune your XSQL pages environment. Table 27-2 defines the legal parameters.
Table 27-2 XSQL Configuration File Settings
Configuration Setting Name | Description |
---|---|
XSQLConfig/servlet/output-buffer-size |
Sets the size in bytes of the buffered output stream. If the servlet engine already buffers I/O to the servlet output stream, you can set to 0 (the default) to avoid additional buffering. Any non-negative integer is valid. |
XSQLConfig/servlet/suppress-mime-charset/media-type |
The XSQL servlet sets the HTTP ContentType header to indicate the MIME type of the resource returned to the request. By default, the servlet includes the optional character set data in the MIME type. For a particular MIME type, you can suppress the inclusion of the character set data by including a <media-type> element, with the desired MIME type as its contents. You can list any number of <media-type> elements. Valid value is any string. |
XSQLConfig/processor/character-set-conversion/ default-charsetNOTE: Setting name is a single line. It is displayed on two lines due to space constraints. |
Performs character set conversion by default on the value of HTTP parameters to compensate for the default character set used by most servlet engines. The default base character set used for conversion is the Java 8859_1 , which corresponds to the IANA ISO-8859-1 set. If your servlet engine uses a different character set as its base, then you can specify this value here.
To suppress character set conversion, specify the empty element Valid values are any Java character set name or |
XSQLConfig/processor/reload-connections-on-error |
Connection definitions are cached when the XSQL pages processor is initialized. Set to yes (default) to cause the processor to reread the XSQLConfig.xml file to reload connection definitions if an attempt is made to request a connection name that is not in the cached connection list. The yes setting is useful for adding new <connection> definitions to the file while the servlet is running. Set to no to avoid reloading the connection definition file when a connection name is not found in the in-memory cache. Valid values are yes and no . |
XSQLConfig/processor/default-fetch-size |
Sets the default value of the row fetch size for retrieving information from SQL queries. It only takes effect when you use the Oracle JDBC driver; otherwise the setting is ignored. This technique reduces network round trips to the database from the servlet engine running in a different tier.
Default is |
XSQLConfig/processor/page-cache-size |
Sets the size of the cache for XSQL page templates and so determines the maximum number of XSQL pages that are cached. Least recently used pages move out of the cache if you go above this number. Default is 25 . Any nonzero positive integer is valid. |
XSQLConfig/processor/stylesheet-cache-size |
Sets the size of the cache for XSLT stylesheets and so determines the maximum number of XSQL pages that are cached. Least recently used pages move out of the cache if you go above this number. Default is 25 . Any nonzero positive integer is valid. |
XSQLConfig/processor/stylesheet-pool/initial |
Each cached stylesheet is a pool of cached stylesheet instances to improve throughput. Sets the initial number of stylesheets to be allocated in each stylesheet pool.
Default is |
XSQLConfig/processor/stylesheet-pool/increment |
Sets the number of stylesheets allocated when the stylesheet pool must grow due to increased load on the server.
Default is |
XSQLConfig/processor/stylesheet-pool/timeout-seconds |
Sets the number of seconds of inactivity before a stylesheet instance in the pool is removed to free resources as the pool tries to shrink back to its initial size.
Default is |
XSQLConfig/processor/connection-pool/initial |
Controls the initial number of JDBC connections allocated in each connection pool. The XSQL pages processor's default connection manager implements connection pooling to improve throughput.
Default is |
XSQLConfig/processor/connection-pool/increment |
Sets the number of connections allocated when the connection pool must grow due to increased load on the server.
Default is |
XSQLConfig/processor/connection-pool/timeout-seconds |
Sets the number of seconds of inactivity before a JDBC connection in the pool is removed to free resources as the pool tries to shrink back to its initial size.
Default is |
XSQLConfig/processor/connection-pool/dump-allowed |
Determines whether a diagnostic report of connection pool activity can be requested by passing the dump-pool=y parameter in the page request.
Default is |
XSQLConfig/processor/connection-manager/factory |
Specifies the fully-qualified Java class name of the XSQL connection manager factory implementation. If not specified, default is XSQLConnectionManagerFactoryImpl .
Valid value is any class name that implements the |
XSQLConfig/processor/owa/fetch-style |
Sets the default OWA Page Buffer fetch style used by the <xsql:include-owa> action. Valid values are CLOB (default) or TABLE .
If set to
|
XSQLConfig/processor/timing/page |
Determines whether the XSQL page processor adds an xsql-timing attribute to the document element of the page whose value reports the elapsed number of milliseconds required to process the page.
Valid values are |
XSQLConfig/processor/timing/action |
Determines whether a the XSQL page processor adds comment to the page just before the action element whose contents reports the elapsed number of milliseconds required to process the action.
Valid values are |
XSQLConfig/processor/logger/factory |
Specifies the fully-qualified Java class name of a custom XSQL logger factory implementation. If not set, then no logger is used.
Valid value is any class name that implements the |
XSQLConfig/processor/error-handler/class |
Specifies the fully-qualified Java class name of a custom XSQL error handler. The specified handler is the default error handler implementation. If not set, then the default error handler is used.
Valid value is any class name that implements the |
XSQLConfig/processor/xml-parsing/preserve-whitespace |
Determines whether the XSQL pages processor preserves whitespace when parsing XSQL pages and XSLT stylesheets.
Valid values are |
XSQLConfig/processor/security/stylesheet/defaults/ allow-client-styleNOTE: Setting name is a single line. It is displayed on two lines due to space constraints. |
Prevents client overriding of the stylesheet. Valid values are yes and no .
During development it is sometimes useful to use the XSQL stylesheet override feature by providing a value for the You can add the This setting only specifies default behavior. If the attribute value is explicitly specified on the document element for a given XSQL page, its value takes precedence over this global default. |
XSQLConfig/processor/security/stylesheet/ trusted-hosts/hostNOTE: Setting name is a single line. It is displayed on two lines due to space constraints. |
Specifies that any absolute URL to an XSLT stylesheet must be from a trusted host whose name is listed in the configuration file. List any number of <host> elements inside the <trusted-hosts> element. The name of the local machine, localhost , and 127.0.0.1 are trusted hosts by default. Valid values are any hostname or IP address.
The XSLT processor supports Java extension functions. Typically, XSQL pages refer to XSLT stylesheets with relative URLs. |
XSQLConfig/http/proxyhost |
Sets the name of the HTTP proxy server to use when processing URL s with the HTTP protocol.
Valid value is any hostname or IP address. |
XSQLConfig/http/proxyport |
Sets the port number of the HTTP proxy server to use when processing URL s with the HTTP protocol.
Valid value is any nonzero integer. |
XSQLConfig/connectiondefs/connection |
Defines a short name and the JDBC details for a named connection used by the XSQL pages processor.
You may supply any number of |
XSQLConfig/connectiondefs/connection/username |
Defines the username for the current connection. |
XSQLConfig/connectiondefs/connection/password |
Defines the password for the current connection. |
XSQLConfig/connectiondefs/connection/dburl |
Defines the JDBC connection URL for the current connection. |
XSQLConfig/connectiondefs/connection/driver |
Specifies the fully-qualified Java class name of the JDBC driver used for the current connection. If not specified, defaults to oracle.jdbc.driver.OracleDriver . |
XSQLConfig/connectiondefs/connection/autocommit |
Explicitly sets the Auto Commit flag for the current connection. If not specified, the connection uses the JDBC driver default setting for Auto Commit. |
XSQLConfig/serializerdefs/serializer |
Defines a named custom serializer implementation. You can supply any number of <serializer> element children of <serializerdefs> . Each must specify both a <name> and a <class> child element. |
XSQLConfig/serializerdefs/serializer/name |
Defines the name of the current custom serializer definition. |
XSQLConfig/connectiondefs/connection/class |
Specifies the fully-qualified Java class name of the current custom serializer. The class must implement the XSQLDocumentSerializer interface. |
Invokes a user-defined action handler, implemented in Java, for executing custom logic and including custom XML data in a XSQL page. The Java class invoked with this action must implement the oracle.xml.xsql.XSQLActionHandler
interface.
Use <xsql:action>
to perform tasks that are not handled by the built-in action handlers. Custom actions can supply arbitrary XML content to the data page and perform arbitrary processing.
The XSQL page processor processes the actions in a page in the following way:
Constructs an instance of the action handler class with the default constructor.
Initializes the handler instance with the action element object and the page processor context by invoking the method init(Element actionElt, XSQLPageRequest context)
.
Invokes the method that allows the handler to handle the action handleAction(Node result)
.
The syntax for this action is as follows, where handler
is a single, required attribute named whose value is the fully-qualified Java class name of the invoked action, yourpackage
is the Java package, and YourCustomHandler
is the Java class:
<xsql:action handler="yourpackage.YourCustomHandler"/>
Some action handlers expect text content or element content to appear inside the <xsql:action>
element. In this case, use syntax such as the following:
<xsql:action handler="yourpackage.YourCustomHandler">
Some_text
</xsql:action>
You can also use the following syntax:
<xsql:action handler="yourpackage.YourCustomHandler"> <some> <other/> <elements/> <here/> </some> </xsql:action>
The only required attribute is handler
, but you can supply additional attributes to the handler. For example, if yourpackage.YourCustomHandler
is expecting attributes named param1
and param2
, then use the following syntax:
<xsql:action handler="yourpackage.YourCustomHandler" param1="xxx" param2="yyy">
Example 27-1 shows an XSQL page that invokes the myactions.StockQuotes
Java class. It includes stock quotes from Google for any symbols passed in with the symbol
parameter. If this parameter is not supplied, it supplies a default list.
Accepts data posted from an XML document or HTML form and uses the XML SQL Utility (XSU) to delete the content of an XML document in canonical form from a target table or view.
By combining XSU with XSLT, you can transform XML into the canonical format expected by a given table. Afterward, you can use XSU to delete the resulting canonical XML. For a specified database table, the canonical XML form is given by one row of XML output from a SELECT * query against the table.
The syntax for this action is as follows, where table_name
is the name of a table and key
is a list of one or more columns to use as the unique key:
<xsql:delete-request table="table_name" key-columns="key"/>
Table 27-3 lists the optional attributes that you can use on the <xsql:delete-request>
action. Required attributes are in bold
Table 27-3 Attributes for <xsql:delete-request>
Attribute Name | Description |
---|---|
table = "string" |
Name of the table, view, or synonym to use for deleting the XML data. |
key-columns = "string string ..." |
Space-delimited or comma-delimited list of one or more column names. The processor uses the values of these names in the posted XML document to identify the existing rows to delete. |
transform = "URL"
|
Relative or absolute URL of the XSLT transformation to use to transform the document to be deleted into canonical ROWSET/ROW format. |
columns = "string"
|
Relative or absolute URL of the XSLT transformation to use to transform the document to be deleted into canonical ROWSET/ROW format. |
commit = "boolean"
|
If set to yes (default), calls COMMIT on the current connection after a successful execution of the deletion. Valid values are yes and no . |
commit-batch-size = "integer"
|
If a positive, nonzero integer is specified, then after each batch of integer deleted records, the processor issues a COMMIT . The default batch size is zero (0) if not specified, which means that the processor does not commit interim batches. |
date-format = "string"
|
Date format mask to use for interpreting date field values in XML being deleted. Valid values are those documented for the java.text.SimpleDateFormat class. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string Error if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
Example 27-2 specifies that the posted XML document should be transformed with the style.xsl
stylesheet and then deleted from the departments
table. The departments.department_id
column is the primary key for the deletion.
Executes a DML or DDL statement or a PL/SQL block. Typically, you use this tag to include statements that would be executed or rolled back together.
This action requires a database connection provided as a connection="connname"
attribute on the document element of the XSQL page in which it appears.
You cannot set parameter values by binding them in the position of OUT
variables with <xsql:dml>
. Only IN
parameters are supported for binding.
The syntax for the action is as follows, where DML_DDL_or_PLSQL
is a placeholder for a legal DML statement, DDL statement, or PL/SQL block:
<xsql:dml>
DML_DDL_or_PLSQL
</xsql:dml>
Table 27-4 lists the optional attributes that you can use on the <xsql:dml>
action.
Table 27-4 Attributes for <xsql:dml>
Attribute Name | Description |
---|---|
commit = "boolean"
|
If set to yes , calls commit on the current connection after a successful execution of the DML statement. Valid values are yes and no (default). |
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. The values of these parameters are used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string 'Error ' if a nonfatal error occurs while processing this action. Valid value is any parameter name. |
error-statement = "boolean"
|
If set to no , suppresses the inclusion of the offending SQL statement in any <xsql-error> element generated. Valid values are yes (default) and no . |
Example 27-3 inserts the username stored in the webuser
cookie into a request_log
table. Using bind variables guards against SQL injection attacks.
Enables you to include elements and actions nested inside if a specified condition is true. If the condition is true, then all nested XML content and actions are included in the page. If the condition is false, then none of the nested XML content or actions is included (and thus none of the nested actions is executed).
Specify which parameter value is evaluated by supplying the required name
attribute. Both simple parameter names as well as array-parameter names are supported.
Note:
If the parameter being tested does not exist, the test evaluates to false.The syntax for the action is the following, where some_name
is the value of the name
attribute and test_condition
is exactly one of the conditions listed in Table 27-5:
<xsql:if-param name="some_name" test_condition> element_or_action </xsql:if-param>
Any XML content or XSQL action elements can be nested inside an <xsql:if-param>
, including other <xsql:if-param>
elements.
In addition to the required name
attribute, you must pick exactly one of the attributes listed in Table 27-5 to indicate how the parameter value (or values, in the array case) is tested. As with other XSQL actions, the attributes of the <xsql:if-param>
action can contain lexical substitution parameter expressions such as {@paramName}
.
Table 27-5 Attributes for <xsql:if-param>
Attribute Name | Description |
---|---|
exists="yes_or_no"
|
If set to exists="yes" , then this condition tests whether the named parameter exists and has a non-empty value. For an array-valued parameter, it tests whether the array-parameter exists and has at least one non-empty element.
If set to |
equals="stringValue"
|
This condition tests whether the named parameter equals the string value provided. By default the comparison is an exact string match. For a case-insensitive match, supply the additional ignore-case="yes" attribute as well.
For an array-valued parameter, the condition tests whether any element in the array has the indicated value. |
not-equals="stringValue"
|
This condition tests whether the named parameter does not equal the string value provided. By default the comparison is an exact string match. For an array-valued parameter, the condition evaluates to true if none of the elements in the array has the indicated value. |
in-list = "comma-or-space-separated-list"
|
This condition tests whether the named parameter matches any of the strings in the provided list. By default the comparison is an exact string match. For a case-insensitive match, supply the additional ignore-case="yes" attribute as well.
The value of the |
not-in-list = "comma-or-space-separated-list"
|
This tests whether the named parameter does not match any of the strings in the provided list. By default the comparison is an exact string match. For a case-insensitive match, supply the additional ignore-case="yes" attribute as well.
The value of the |
To test whether two different conditions are true, you can use nested <xsql:if-param>
elements as shown in Example 27-4.
Example 27-4 Testing Conditions
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <page connection="demo" xmlns:xsql="urn:oracle-xsql"> <!-- | Set page parameter 'some_param' to value "some_value" if parameter 'a' | exists, and if parameter 'b' has a value equal to "X" +--> <xsql:if-param name="a" exists="yes"> <xsql:if-param name="b" equals="X"> <xsql:set-page-param name="some_param" value="some_value"/> </xsql:if-param> </xsql:if-param> <!-- ... --> </page>
Includes XML content generated by a database stored procedure. This action requires a database connection to be provided by supplying a connection="connname"
attribute on the document element of the XSQL page in which it appears.
The stored procedure uses the standard Oracle Web Agent (OWA) packages (HTP
and HTF
) to "print" the XML tags into the server-side page buffer. Afterwards, the XSQL pages processor fetches, parses, and includes the dynamically-produced XML content in the data page. The stored procedure must generate a well-formed XML page or an appropriate error is displayed.
You can create a wrapper procedure that constructs XML elements with the HTP package. Your XSQL page can invoke the wrapper procedure by using <xsql:include-owa>
.
The syntax for the action is as follows, where PL/SQL_block
is a PL/SQL Block invoking a procedure that uses the HTP or HTF packages:
<xsql:include-owa>
PL/SQL_block
</xsql:include-owa>
Table 27-6 lists the optional attributes supported by this action.
Table 27-6 Attributes for <xsql:include-owa>
Attribute Name | Description |
---|---|
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. The values of these parameters are used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string 'Error ' if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
error-statement = "boolean"
|
If set to no , suppresses the inclusion of the offending SQL statement in any <xsql-error> element generated. Valid values are yes (default) and no . |
Assume that you write a PL/SQL procedure called UpdateStatus
that updates the status of a project. The procedure uses HTP to print an <UpdateStatus>
datagram that contains the element <Success/>
if no errors occur or one or more <Error>
elements if errors occur.
Example 27-5 shows how you can call UpdateStatus
from an XSQL page. The example uses SQL bind variable instead of lexical substitution to prevent the possibility of SQL injection attacks.
Example 27-5 Including XML Content Created by a Stored Procedure
<xsql:include-owa connection="demo" bind-params="project status" xmlns:xsql="urn:oracle-xsql"> UpdateStatus( ?,? ); </xsql:include-owa>
Assume that a user enters an invalid status number for a project into a Web-based form. The form posts the input parameters to an XSQL page as shown in Example 27-5. The XSQL processor returns the following datagram, which an XSLT stylesheet could transform into an HTML error page:
<UpdateStatus> <Error Field="status">Status must be 1, 2, 3, or 4</Error> </UpdateStatus>
Includes an XML representation of the name and value of a single parameter. This technique is useful if an associated XSLT stylesheet needs to refer to parameter values with XPath expressions.
The syntax of the action is as follows, where paramname
is the name of a parameter:
<xsql:include-param name="paramname" />
The required name
attribute supplies the name of the parameter whose value you want to include.
The name
attribute is required; there are no optional attributes.
Example 27-6 uses XPATH to obtain the value of a parameter and represent it in XML.
Example 27-6 Including an XML Representation of a Parameter Value
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <page connection="demo" xmlns:xsql="urn:oracle-xsql" xmlns:p="http://www.companysite.com/products"> <xsql:set-page-param name="productid" xpath="/p:Products/productid"/> <xsql:include-param name="productid"/> </page>
The XML fragment included in the datagram will be as follows:
<productid>12345</productid>
Suppose that you use an array parameter name to indicate that you want to treat the value as an array, as in the following example:
<xsql:include-param name="productid[]"/>
The XML fragment reflects all of the array values, as shown in the following example:
<productid> <value>12345<value> <value>33455</value> <value>88199</value> </productid>
In this array-parameter name scenario, if productid
happens to be a single-valued parameter, then the fragment looks identical to a one-element array, as illustrated in the following example:
<productid> <value>12345<value> </productid>
Includes the posted XML document in the XSQL page. If the user posts an HTML form instead of an XML document, then the XML included is similar to that included by the <xsql:include-request-params>
action.
The syntax of the action is as follows:
<xsql:include-posted-xml/>
None.
Example 27-7 shows a sample XSQL page that includes a posted XML document.
Includes an XML representation of all parameters in the request in the datagram. The action element is replaced in the page at page-request time with a tree of XML elements that represents the parameters available to the request.
This technique is useful if an associated XSLT stylesheet needs to refer to request parameter values with XPath expressions.
When processing pages through the XSQL servlet, the XML included takes the form shown in Example 27-8.
Example 27-8 Including Request Parameters
<request> <parameters> <paramname>value1</paramname> <ParamName2>value2</ParamName2> ... </parameters> <session> <sessVarName>value1</sessVarName> ... </session> <cookies> <cookieName>value1</cookieName> ... </cookies> </request>
When you use the XSQL command-line utility or the XSQLRequest
class, the XML takes the form shown in Example 27-11.
Example 27-9 Including Request Parameters
<request> <parameters> <paramname>value1</paramname> <ParamName2>value2</ParamName2> ... </parameters> </request>
The technique enables you to distinguish request parameters from session parameters or cookies because its value is a child element of <parameters>
, <session>
, or <cookies>
.
The syntax of the action is as follows:
<xsql:include-request-params/>
None.
Example 27-10 shows a sample XSQL page that includes all request parameters in the data page.
Example 27-10 Including Request Parameters
<?xml version="1.0"?> <?xml-stylesheet type="text/xsql" href="cookie_condition.xsl"?> <page connection="demo" xmlns:xsql="urn:oracle-xsql"> <xsql:include-request-params/> </page>
The cookie_condition.xsl
stylesheet chooses an output format based on whether the siteuser
cookie is present. Example 27-11 shows a fragment of the stylesheet.
Includes the XML contents of a local, remote, or database-driven XML resource in your datagram. You can specify the resource by URL or SQL statement. The server can deliver a resource that is a static XML file or dynamically created XML from a programmatic resource such as a servlet or CGI program.
The syntax for this action is as follows, where URL
is a relative URL or an absolute, HTTP-based URL to retrieve XML from another Web site:
<xsql:include-xml href="URL"/>
Alternatively, you can use the following syntax, where SQL_statement
is a SQL SELECT
statement selecting a single row containing a single CLOB
or VARCHAR2
column value:
<xsql:include-xml>
SQL_statement
</xsql:include-xml>
The href
attribute and SQL statement are mutually exclusive. If you provide one, then the other is not allowed.
Table 27-7 lists the attributes supported by this action. Required attributes are in bold.
Table 27-7 Attributes for <xsql:include-xml>
Attribute Name | Description |
---|---|
href="URL" |
The absolute, relative, or parameterized URL of the XML resource to be included. The resource can be a static file dynamic source. |
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. The values for these name will be used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string 'Error ' if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
Example 27-12 includes an XML document retrieved by a database query. The XML content is a CLOB
-valued member field of a user-defined type. The XML included must come from a VARCHAR2
or CLOB
column, not an XMLType
.
Includes the XML output of one XSQL page in another page. You can create a page that assembles the contents—optionally transformed—from other XSQL pages.
If the aggregated page contains an <?xml-stylesheet?>
processing instruction, then this stylesheet is applied before the result is aggregated. Thus, you can use <xsql:include-xsql>
to chain XSLT stylesheets.
When one XSQL page aggregates another page by using <xsql:include-xsql>
, all request-level parameters are visible to the nested page. For pages processed by the XSQL Servlet, the visible data includes session-level parameters and cookies. None of the aggregating page's page-private parameters are visible to the nested page.
The syntax for this action is as follows, where XSQL_page
is a relative or absolute URL of an XSQL page to be included:
<xsql:include-xsql href="XSQL_page"/>
Table 27-8 lists the attributes supported by this action. Required attributes are in bold; all others are optional.
Table 27-8 Attributes for <xsql:include-xsql>
Attribute Name | Description |
---|---|
href="string" |
Relative or absolute URL of XSQL page to be included. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string Error if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
reparse = "boolean"
|
Indicates whether output of the included XSQL page must be reparsed before it is included. Valid values are no (default) and yes .
This attribute is useful if the included XSQL page selects the text of an XML document fragment that the including page wants to treat as elements. |
Example 27-13 displays an XSQL page that lists discussion forum categories.
<?xml version="1.0"?> <xsql:query connection="demo" xmlns:xsql="urn:oracle-xsql"> SELECT name FROM categories ORDER BY name </xsql:query>
Example 27-14 shows how you can include the results of the page in Example 27-13 into a page that lists the ten most recent topics in the current forum.
Example 27-14 TopTenTopics.xsql
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <top-ten-topics connection="demo" xmlns:xsql="urn:oracle-xsql"> <topics> <xsql:query max-rows="10"> SELECT subject FROM topics ORDER BY last_modified DESC </xsql:query> </topics> <categories> <xsql:include-xsql href="Categories.xsql"/> </categories> </top-ten-topics>
You can also use <xsql:include-xsql>
to apply an XSLT stylesheet to an included page. Assume that you write the following XSLT stylesheets:
cats-as-html.xsl
, which renders the topics in HTML
cats-as-wml.xsl
, which renders the topics in WML
One approach for catering to two different types of devices is to create different XSQL pages for each device. Example 27-15 shows an XSQL page that aggregates Categories.xsql
and applies the cats-as-html.xsl
stylesheet.
Example 27-15 HTMLCategories.xsql
<?xml version="1.0"?> <!-- HTMLCategories.xsql --> <?xml-stylesheet type="text/xsl" href="cats-as-html.xsl"?> <xsql:include-xsql href="Categories.xsql" xmlns:xsql="urn:oracle-xsql"/>
Example 27-16 shows an XSQL page that aggregates Categories.xsql
and applies the cats-as-html.xsl
stylesheet for delivering to wireless devices.
Inserts the value of a parameter into a table or view. Use this tag when the client is posting a well-formed XML document as text in an HTTP parameter or individual HTML form field.
By combining the XML SQL Utility (XSU) with XSLT, you can transform XML into the canonical format expected by a given table. Afterward, you can use XSU to insert the resulting canonical XML. For a specified database table, the canonical XML form is given by one row of XML output from a SELECT *
query against the table.
The syntax for this action is as follows, where table_or_view_name
is a relative or absolute URL of an XSQL page to be included:
<xsql:insert-param table="table_or_view_name" name="string"/>
Table 27-9 lists the optional attributes that you can use on the <xsql:insert-param>
action.
Table 27-9 Attributes for <xsql:insert-param>
Attribute Name | Description |
---|---|
name="string" |
Name of the parameter whose value contains XML to be inserted. |
table="string" |
Name of the table, view, or synonym to use for inserting the XML data. |
transform = "URL"
|
Relative or absolute URL of the XSLT transformation to use to transform the document to be inserted into canonical ROWSET/ROW format. |
columns = "string"
|
Space-delimited or comma-delimited list of one or more column names whose values will be inserted. If supplied, then only these columns will be inserted. If not supplied, all columns will be inserted, with NULL values for columns whose values do not appear in the XML document. |
commit = "boolean"
|
If set to yes , calls commit on the current connection after a successful execution of the insert. Valid values are yes (default) and no . |
commit-batch-size = "integer"
|
If a positive, nonzero number integer is specified, then after each batch of integer inserted records, the XSQL processor issues a COMMIT . Default batch size is zero (0 ), which instructs the processor not to commit interim batches. |
date-format = "string"
|
Date format mask to use for interpreting date field values in XML being inserted. Valid values are those for the java.text.SimpleDateFormat class. |
error-param = "string"
|
Name of a page-private parameter that must be set to Error if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
Example 27-17 parses and transforms the contents of the HTML form parameter xmlfield
for database insert.
Accepts data posted from an XML document or HTML form and uses the XML SQL Utility (XSU) to insert the content of an XML document in canonical form into a target table or view.
If an HTML Form has been posted, then the posted XML document is materialized from HTTP request parameters, cookies, and session variables. The XML document has the following form:
<request> <parameters> <param1>value1</param1> : </paramN>valueN</paramN> </parameters> : </request>
By combining XSU with XSLT, you can transform XML into the canonical format expected by a given table. The XSQL engine uses XSU to insert the resulting canonical XML. For a specified database table, the canonical XML form is given by one row of XML output from a SELECT *
query against the table.
If you target a database view with an INSERT
, then you can create INSTEAD OF INSERT
triggers on the view to further automate the handling of the posted data. For example, an INSTEAD OF INSERT
trigger on a view can use PL/SQL to check for the existence of a record and intelligently choose whether to do an INSERT
or an UPDATE
depending on the result.
The syntax for this action is as follows:
<xsql:insert-request table="table"/>
Table 27-10 lists the optional attributes that you can use on the <xsql:insert-request>
action.
Table 27-10 Attributes for <xsql:insert-request>
Attribute Name | Description |
---|---|
table = "string" |
Name of the table, view, or synonym to use for inserting the XML data. |
transform = "URL"
|
Relative or absolute URL of the XSLT transformation to use to transform the document to be inserted into canonical ROWSET/ROW format. |
columns = "string"
|
Relative or absolute URL of the XSLT transformation to use to transform the document to be inserted into canonical ROWSET/ROW format. |
commit = "boolean"
|
If set to yes (default), calls COMMIT on the current connection after a successful execution of the insert. Valid values are yes and no . |
commit-batch-size = "integer"
|
If a positive, nonzero number integer is specified, then after each batch of integer inserted records, the processor issues a COMMIT . The default batch size is zero (0) if not specified, which means that the processor does not commit interim batches. |
date-format = "string"
|
Date format mask to use for interpreting date field values in XML being inserted. Valid values are those documented for the java.text.SimpleDateFormat class. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string Error if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
Example 27-18 parses and transforms the contents of the posted XML document or HTML Form for insert.
Executes a SQL select statement and includes a canonical XML representation of the query result set in the data page. This action requires a database connection to be provided by supplying a connection="
connname"
attribute on the document element of the XSQL page in which it appears.
The syntax for the action is the following:
<xsql:query>
SELECT_Statement
</xsql:query>
Any legal SQL select statement is permissible as a substitution for the SELECT_Statement
placeholder. If the select statement produces no rows, then you can provide a fallback query by including a nested <xsql:no-rows-query>
element as follows:
<xsql:query> SELECT_Statement <xsql:no-rows-query> Fallback_SELECT_Statement </xsql:no-rows-query> </xsql:query>
An <xsql:no-rows-query>
element can itself contain nested <xsql:no-rows-query>
elements to any level of nesting. The options available on the <xsql:no-rows-query>
are identical to those legal on the <xsql:query>
action element.
The optional attributes listed in Table 27-11 can be supplied to control various aspects of the data retrieved and the XML produced by the <xsql:query>
action.
Table 27-11 Attributes for <xsql:query>
Attribute Name | Description |
---|---|
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. The values of these parameters are used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
date-format = "string"
|
Date format mask to use for formatted date column and attribute values in the XML that is queried. Valid values are the same values legal for the java.text.SimpleDateFormat class. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string 'Error ' if a nonfatal error occurs while processing this action. Valid value is any parameter name. |
error-statement = "boolean"
|
If set to no , suppresses the inclusion of the offending SQL statement in any <xsql-error> element generated. Valid values are yes (default) and no . |
fetch-size = "integer"
|
Number of records to fetch in each round trip to the database. If not set, the default value is used as specified by the /XSQLConfig/processor/default-fetch-size configuration setting in XSQLConfig.xml . |
id-attribute = "string"
|
XML attribute name to use instead of the default num for uniquely identifying each row in the result set. If the value is the empty string, then the row id attribute is suppressed. |
id-attribute-column = "string"
|
Case-sensitive name of the column in the result set whose value must be used in each row as the value of the row id attribute. The default is to use the row count as the value of the row id attribute. |
include-schema = "boolean"
|
If set to yes , includes an inline XML schema that describes the structure of the result set. Valid values are yes and no (default). |
max-rows = "integer"
|
Maximum number of rows to fetch after optionally skipping the number of rows set by the skip-rows attribute. If not specified, the default is to fetch all rows. |
null-indicator = "boolean"
|
Indicates whether to signal that a column's value is NULL by including the NULL="Y" attribute on the element for the column. By default, columns with NULL values are omitted from the output. Valid values are yes and no (default). |
row-element = "string"
|
XML element name to use instead of the default <ROW> for the rowset of query results. Set to the empty string to suppress generating a containing <ROW> element for each row in the result set. |
rowset-element = "string"
|
XML element name to use instead of the default <ROWSET> for the rowset of query results. Set to the empty string to suppress generating a containing <ROWSET> element. |
skip-rows = "integer"
|
Number of rows to skip before fetching rows from the result set. Can be combined with max-rows for stateless paging through query results. |
tag-case = "string"
|
Valid values are lower and upper . If not specified, the default is to use the case of column names as specified in the query as corresponding XML element names. |
Example 27-20 shows a simple XSQL page.
<?xml version="1.0"?> <xsql:query connection="xmlbook" xmlns:xsql="urn:oracle-xsql"> SELECT 'Hello, World!' AS text FROM DUAL</xsql:query>
If you save Example 27-20 as hello.xsql
and execute it in a browser, the XSQL page processor returns the following XML:
<?xml version = '1.0'?> <ROWSET> <ROW num="1"> <TEXT>Hello, World!</TEXT> </ROW> </ROWSET>
By default, the XML produced by a query reflects the column structure of its result set, with element names matching the names of the columns. Columns in the result with the following nested structure produce nested elements that reflect this structure:
Object types
Collection types
CURSOR expressions
The result of a typical query containing different types of columns and returning one row might look like Example 27-20.
Example 27-20 Nested Structure Example
<ROWSET> <ROW id="1"> <VARCHARCOL>Value</VARCHARCOL> <NUMBERCOL>12345</NUMBERCOL> <DATECOL>12/10/2001 10:13:22</DATECOL> <OBJECTCOL> <ATTR1>Value</ATTR1> <ATTR2>Value</ATTR2> </OBJECTCOL> <COLLECTIONCOL> <COLLECTIONCOL_ITEM> <ATTR1>Value</ATTR1> <ATTR2>Value</ATTR2> </COLLECTIONCOL_ITEM> <COLLECTIONCOL_ITEM> <ATTR1>Value</ATTR1> <ATTR2>Value</ATTR2> </COLLECTIONCOL_ITEM> </COLLECTIONCOL> <CURSORCOL> <CURSORCOL_ROW> <COL1>Value1</COL1> <COL2>Value2</COL2> </CURSORCOR_ROW> </CURSORCOL> </ROW> </ROWSET>
A <ROW>
element repeats for each row in the result set. Your query can use standard SQL column aliasing to rename the columns in the result, which effectively renames the XML elements that are produced. Column aliasing is required for columns whose names otherwise are illegal names for an XML element.
For example, an <xsql:query>
action as shown in Example 27-21 produces an error because the default column name for the calculated expression is an illegal XML element name.
Example 27-21 Query with Error
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <xsql:query connection="demo" xmlns:xsql="urn:oracle-xsql"> SELECT TO_CHAR(hire_date,'DD-MON') FROM employees </xsql:query>
You can fix the problem by using column aliasing as shown in Example 27-22.
Executes an arbitrary stored function returning a REF
CURSOR
and includes the query result set in canonical XML format. This action requires a database connection to be provided by supplying a connection="
connname"
attribute on the document element of the XSQL page in which it appears.
Use this tag to invoke a stored procedure that determines what the query is and returns a cursor to the query. Used in this way, this tag also provides a weak level of security because it can hide the query from direct inspection.
The syntax of the action is as follows, where SCHEMA_NAME
represents an optional database schema name, PACKAGE_NAME
represents an optional PL/SQL package name, and FUNCTION_NAME
(required) specifies the name of a PL/SQL function:
<xsql:ref-cursor-function> [SCHEMA_NAME.][PACKAGE_NAME.]FUNCTION_NAME(args); </xsql:ref-cursor-function>
The optional attributes are the same as for the <xsql:query>
action listed in Table 27-11 except that fetch-size
is not available for <xsql:ref-cursor-function>
.
By exploiting dynamic SQL in PL/SQL, a function can conditionally construct a dynamic query before a cursor handle to its result set is returned to the XSQL page processor. The return value of the function must be of type REF
CURSOR
. Consider the PL/SQL package shown in Example 27-23.
Example 27-23 DynCursor PL/SQL Package
CREATE OR REPLACE PACKAGE DynCursor IS TYPE ref_cursor IS REF CURSOR; FUNCTION DynamicQuery(id NUMBER) RETURN ref_cursor; END; CREATE OR REPLACE PACKAGE BODY DynCursor IS FUNCTION DynamicQuery(id NUMBER) RETURN ref_cursor IS the_cursor ref_cursor; BEGIN IF id = 1 THEN -- Conditionally return a dynamic query as a REF CURSOR OPEN the_cursor -- An employees Query FOR 'SELECT employee_id, email FROM employees'; ELSE OPEN the_cursor -- A departments Query FOR 'SELECT department_name, department_id FROM departments'; END IF; RETURN the_cursor; END; END;
An <xsql:ref-cursor-function>
can include the dynamic results of the REF
CURSOR
returned by this function as shown in Example 27-24.
Sets an HTTP cookie to a value. By default, the value remains for the lifetime of the current browser, but you can change its lifetime by supplying the optional max-age
attribute. The value to be assigned to the cookie can be supplied by a combination of static text and other parameter values, or from the result of a SQL SELECT
statement.
Because this feature is specific to the HTTP protocol, this action is only effective if the XSQL page in which it appears is processed by the XSQL servlet. If this action is encountered in an XSQL page processed by the XSQL command-line utility or the XSQLRequest
programmatic API, then it does nothing.
If you use the SQL statement option, then a single row is fetched from the result set and the parameter is assigned the value of the first column. This use requires a database connection to be provided by supplying a connection="connname"
attribute on the document element of the XSQL page in which it appears.
If you need to set several cookie values based on the results of a single SQL statement, then do not use the name
attribute. Instead, you can use the names
attribute and supply a space-or-comma-delimited list of one or more cookie names.
The syntax for this action is as follows, where paramname
is the name of a parameter:
<xsql:set-cookie name="paramname" value="value"/>
Alternatively, you can use the following syntax, where SQL_statement
is a SQL SELECT
statement and paramname
is the name of a parameter:
<xsql:set-cookie name="paramname"> SQL_statement </xsql:set-cookie>
Either the name
or the names
attribute is required. The value
attribute and the contained SQL statement are mutually exclusive. The number of columns in the select list must match the number of cookies being set or an error message results.
Table 27-12 lists the attributes supported by this action. Attributes in bold are required; all others are optional.
Table 27-12 Attributes for <xsql:set-cookie>
Attribute Name | Description |
---|---|
name = "string" |
Name of the cookie whose value you want to set. You must use name or names but not both. |
names = "string string ..." |
Space-or-comma-delimited list of the cookie names whose values you want to set. You must use name or names but not both. |
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. Values are used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
domain = "string"
|
Domain in which cookie value is valid and readable. If domain is not set explicitly, it defaults to the fully-qualified host name (for example, server.biz.com ) of the document creating the cookie. |
error-param = "string"
|
Name of a page-private parameter that is set to the string 'Error ' if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
ignore-empty-value = "boolean"
|
Indicates whether the cookie assignment is ignored if the value to which it is being assigned is an empty string.Valid values are yes and no (default). |
immediate = "boolean"
|
Indicates whether the cookie assignment is immediately visible to the current page. Typically, cookies set in the current request are not visible until the browser sends them back to the server in a subsequent request.Valid values are yes and no (default). |
max-age = "integer"
|
Sets the maximum age of the cookie in seconds. Default is to set the cookie to expire when users current browser session terminates. |
only-if-unset = "boolean"
|
Indicates whether the cookie assignment only occurs when the cookie currently does not exists.Valid values are yes and no (default). |
path = "string"
|
Relative URL path within domain in which cookie value is valid and readable. If path is not set explicitly, then it defaults to the URL path of the document creating the cookie. |
value = "string"
|
Sets the value to assign to the cookie. |
Example 27-25 sets the HTTP cookie to the value of the parameter named choice
.
Example 27-25 Setting a Cookie to a Parameter Value
<?xml version="1.0"?> <xsql:set-cookie name="last_selection" value="{@choice}" xmlns:xsql="urn:oracle-xsql"/>
Example 27-3 sets the HTTP cookie to a value selected from the database.
Example 27-26 Setting a Cookie to a Database-Generated Value
<?xml version="1.0"?> <xsql:set-cookie name="shopping_cart_id" bind-params="user" connection="demo" xmlns:xsql="urn:oracle-xsql"> SELECT cartmgr.new_cart_id(UPPER(?)) FROM DUAL </xsql:set-cookie>
Example 27-4 sets three cookies based on the result of a single SELECT
statement.
Example 27-27 Setting Three Cookies
<?xml version="1.0"?> <xsql:set-cookie names="paramname1 paramname2 paramname3" connection="demo" xmlns:xsql="urn:oracle-xsql"> SELECT expression_or_column1, expression_or_column2, expression_or_column3 FROM table WHERE clause_identifying_a_single_row </xsql:set-cookie>
Sets a page-private parameter to a value. The value can be supplied by a combination of static text and other parameter values, or alternatively from the result of a SQL SELECT
statement.
If you use the SQL statement option, then the program fetches a single row from the result set and assigns the parameter the value of the first column. This usage requires a database connection to be provided by supplying a connection="connname"
attribute on the document element of the XSQL page in which it appears.
As an alternative to providing the value
attribute, or a SQL statement, you can supply the xpath
attribute to set the page-level parameter to the value of an XPath expression. The XPath expression is evaluated against an XML document or HTML form that has been posted to the XSQL pages processor. The value of the xpath
attribute can be any valid XPath expression, optionally built using XSQL parameters as part of the attribute value like any other XSQL action element.
After a page-private parameter is set, subsequent action handlers can use this value as a lexical parameter, for example {@po_id}
. Alternatively, action handlers can use this value as a SQL bind parameter value; they can reference its name in the bind-params
attribute of any action handler that supports SQL operations.
If you need to set multiple session parameter values based on the results of a single SQL statement, instead of using the name
attribute, then you can use the names
attribute. You can supply a list, delimited by spaces or commas, of one or more session parameter names.
The syntax for this action is as follows, where paramname
is the name of a parameter and value
is a value:
<xsql:set-page-param name="paramname" value="value"/>
Alternatively, you can use the following syntax, where SQL_statement
is a SQL SELECT
statement and paramname
is the name of a parameter:
<xsql:set-page-param nname="paramname"> SQL_statement </xsql:set-page-param>
Alternatively, you can use the following syntax, where paramname
is the name of a parameter and where expression
is an XPath expression:
<xsql:set-page-param name="paramname" xpath="expression"/>
Either the name
or the names
attribute is required. The value
attribute and the contained SQL statement are mutually exclusive.
Table 27-13 lists the attributes supported by this action. Attributes in bold are required; all others are optional.
Table 27-13 Attributes for <xsql:set-page-param>
Attribute Name | Description |
---|---|
name = "string" |
Name of the page-private parameter whose value you want to set. |
names = "string string ..." |
Space-or-comma-delimited list of the page parameter names whose values you want to set. Either use the name or the names attribute, but not both. |
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. The values of these parameters are used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
error-param = "string"
|
Name of a page-private parameter that must be set to the string 'Error ' if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
ignore-empty-value = "boolean"
|
Indicates whether the page-level parameter assignment is ignored if the value to which it is being assigned is an empty string.Valid values are yes and no (default). |
quote-array-values = "boolean"
|
If the parameter name is a simple-valued parameter name (for example, myparam ) and if treat-list-as-array="yes" is specified, then specifying quote-array-values="yes" will surround each string token with single quotes before separating the values with commas. Valid values are yes and no (default). |
treat-list-as-array = "boolean"
|
Indicates whether the string-value assigned to the parameter is tokenized into an array of separate values before assignment. If any comma is present in the string, then the comma is used for separating tokens. Otherwise, spaces are used.Valid values are yes and no . The default value is yes if the parameter name being set is an array parameter name (for example, myparam[] ), and default is no if the parameter name being set is a simple-valued parameter name like myparam . |
value = "string"
|
Sets the value to assign to the parameter. |
xpath = "XPathExpression"
|
Sets the value of the parameter to an XPath expression evaluated against an XML document or HTML form that has been posted to the XSQL pages processor. |
Example 27-28 sets multiple parameter values based on the results of a single SQL statement.
Example 27-28 Setting Multiple Page Parameters
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <xsql:set-page-param names="paramname1 paramname2 paramname3" connection="demo" xmlns:xsql="urn:oracle-xsql> SELECT expression_or_column1, expression_or_column2, expression_or_column3 FROM table WHERE clause_identifying_a_single_row </xsql:set-page-param>
Example 27-29 sets the page-level parameter to a value selected from database and then uses it as the value of an xsql:query
attribute.
Example 27-29 Setting a Parameter to a Database-Generated Value
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <page connection="demo" xmlns:xsql="urn:oracle-xsql"> <xsql:set-page-param name="max-rows-pref"> SELECT max_rows FROM user_profile WHERE userid = {@userid} </xsql:set-page-param> <xsql:query max-rows="{@max-rows-pref}"> SELECT title, url FROM newsstory ORDER BY date_entered DESC </xsql:query> </page>
Sets an HTTP session-level parameter to a value. The value of the session-level parameter remains for the lifetime HTTP session of the current browser user. The session is controlled by the Web server. The value can be supplied by a combination of static text and other parameter values or from the result of a SQL SELECT
statement.
Because this feature is specific to Java servlets, this action is only effective if the XSQL page in which it appears is processed by the XSQL servlet. If this action occurs in an XSQL page processed by the XSQL command-line utility or the XSQLRequest
programmatic API, then it does nothing.
If you use the SQL statement option, the XSQL processor fetches a single row from the result set and assigns the parameter the value of the first column. This use requires a database connection to be provided by supplying a connection="connname"
attribute on the document element of the XSQL page in which it appears.
To set several session parameter values based on the results of a single SQL statement, do not use the name
attribute. Instead, use the names
attribute and supply a space-or-comma-delimited list of one or more session parameter names.
The syntax for this action is as follows, where paramname
is the name of a parameter and where value
is a value:
<xsql:set-session-param name="paramname" value="value"/>
Alternatively, you can use the following syntax, where SQL_statement
is a SQL SELECT
statement and paramname
is the name of a parameter:
<xsql:set-session-param name="paramname"> SQL_statement </xsql:set-session-param>
Either the name
or the names
attribute is required. The value
attribute and the contained SQL statement are mutually exclusive.
Table 27-14 lists the optional attributes supported by this action. Attributes in bold are required; all others are optional.
Table 27-14 Attributes for <xsql:set-session-param>
Attribute Name | Description |
---|---|
name = "string" |
Name of the session-level variable whose value you want to set. Either use the name or the names attribute, but not both. |
names = "string string ..." |
Space-or-comma-delimited list of the session parameter names whose values you want to set. Either use the name or the names attribute, but not both. |
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. The parameter values are used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
error-param = "string"
|
Name of a page-private parameter that is set to the string 'Error ' if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
ignore-empty-value = "boolean"
|
Indicates whether the session-level parameter assignment is ignored if the value to which it is being assigned is an empty string. Valid values are yes and no (default). |
only-if-unset = "boolean"
|
Indicates whether the session variable assignment only occurs when the session variable currently does not exists.Valid values are yes and no (default). |
quote-array-values = "boolean"
|
If the parameter name is a simple-valued parameter name (for example, myparam ) and if treat-list-as-array="yes" is specified, then specifying quote-array-values="yes" surrounds each string token with single quotes before separating the values with commas. Valid values are yes and no (default). |
treat-list-as-array = "boolean"
|
Indicates whether the string-value assigned to the parameter is tokenized into an array of separate values before assignment. If any comma is present in the string, then the comma is used for separating tokens. Otherwise, spaces are used.Valid values are yes and no . The default value is yes if the parameter name being set is an array parameter name (for example, myparam[] ), and default is no if the parameter name being set is a simple-valued parameter name like myparam . |
value = "string"
|
Sets the value to assign to the parameter. |
Example 27-30 sets multiple session parameter values based on the results of a single SELECT
statement.
Example 27-30 Setting Session Parameters
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <page connection="demo" xmlns:xsql="urn:oracle-xsql"> <xsql:set-session-param names="paramname1 paramname2 paramname3"> SELECT expression_or_column1, expression_or_column2, expression_or_column3 FROM table WHERE clause_identifying_a_single_row </xsql:set-session-param> <!-- ... --> </page>
Sets a top-level XSLT stylesheet parameter to a value. The value can be supplied by a combination of static text and other parameter values, or from the result of a SQL SELECT
statement. The stylesheet parameter will be set on any stylesheet used during the processing of the current page.
If you use the SQL statement option, then a single row is fetched from the result set and the parameter is assigned the value of the first column. This use requires a database connection to be provided by supplying a connection="connname"
attribute on the document element of the XSQL page in which it appears.
To set several stylesheet parameter values based on the results of a single SQL statement, do not use the name
attribute. You can use the names
attribute and supply a space-or-comma-delimited list of one or more stylesheet parameter names.
The syntax for this action is as follows, where paramname
is the name of a parameter and where value
is a value:
<xsql:set-stylesheet-param name="paramname" value="value"/>
Alternatively, you can use the following syntax, where SQL_statement
is a SQL SELECT
statement and paramname
is the name of a parameter:
<xsql:set-stylesheet-param name="paramname">
SQL_statement
</xsql:set-stylesheet-param>
Either the name
or the names
attribute is required. The value
attribute and the contained SQL statement are mutually exclusive.
Table 27-15 lists the optional attributes supported by this action. Attributes in bold are required; all others are optional.
Table 27-15 Attributes for <xsql:set-stylesheet-param>
Attribute Name | Description |
---|---|
name = "string" |
Name of the top-level stylesheet parameter whose value you want to set. |
names = "string string ..." |
Space-or-comma-delimited list of the top-level stylesheet parameter names whose values you want to set. Use the name or the names attribute, but not both. |
bind-params = "string"
|
Ordered, space-delimited list of one or more XSQL parameter names. Parameter values are used to bind to the JDBC bind variable in the appropriate sequential position in the SQL statement. |
error-param = "string"
|
Name of a page-private parameter that has to be set to the string 'Error ' if a non-fatal error occurs while processing this action. Valid value is any parameter name. |
ignore-empty-value = "boolean"
|
Indicates whether the stylesheet parameter assignment is to be ignored if the value to which it is being assigned is an empty string. Valid values are yes and no (default). |
value = "string"
|
Sets the value to assign to the parameter. |
Example 27-31 associate a stylesheet and uses the <xsql:set-stylesheet-param>
action element to assign the value of the XSQL page parameter named p_table
to the XSLT top-level stylesheet parameter named table
.
Example 27-31 Setting a Stylesheet Parameter
<?xml version="1.0"?> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <page connname="xmlbook" connection="{@p_connname}"> <xsql:query null-indicator="yes" xmlns:xsql="urn:oracle-xsql"> <![CDATA[ SELECT * FROM {@p_table} WHERE rownum < 2 ]]> </xsql:query> <xsql:set-stylesheet-param name="table" value="{@p_table}" xmlns:xsql="urn:oracle-xsql" /> </page>
Accepts data posted from an XML document or HTML form and uses the XML SQL Utility (XSU) to update the content of an XML document in canonical form from a target table or view.
By combining XSU with XSLT, you can transform XML into the canonical format expected by a given table. Afterward, you can use XSU to update the resulting canonical XML. For a specified database table, the canonical XML form is given by one row of XML output from a SELECT *
query against the table.
The syntax for this action is as follows:
<xsql:update-request table="table_name"/>
Table 27-3 lists the attributes that you can use on the <xsql:update-request>
action. Required attributes are in bold.
Table 27-16 Attributes for <xsql:update-request>
Attribute Name | Description |
---|---|
table = "string" |
Name of the table, view, or synonym to use for updating the XML data. |
key_columns = "string string ..." |
Space-delimited or comma-delimited list of one or more column names. The processor uses the values of these names in the posted XML document to identify the existing rows to update. |
transform = "URL"
|
Relative or absolute URL of the XSLT transformation to use to transform the document to be updated into canonical ROWSET/ROW format. |
columns = "string"
|
Relative or absolute URL of the XSLT transformation to use to transform the document to be updated into canonical ROWSET/ROW format. |
commit = "boolean"
|
If set to yes (default), calls COMMIT on the current connection after a successful execution of the update. Valid values are yes and no . |
commit-batch-size = "integer"
|
If a positive, nonzero integer is specified, then after each batch of integer updated records, the processor issues a COMMIT . The default batch size is zero (0 ) if not specified, which means that the processor does not commit interim batches. |
date-format = "string"
|
Date format mask to use for interpreting date field values in XML being updated. Valid values are those for the java.text.SimpleDateFormat class. |
error-param = "string"
|
Name of a page-private parameter that must be set to Error if a nonfatal error occurs while processing this action. Valid value is any parameter name. |
Example 27-32 parses and transforms the contents of the posted XML document or HTML Form for update.