Skip Headers
Oracle® Containers for J2EE Services Guide
10g (10.1.3.1.0)

Part Number B28958-01
Go to Documentation Home
Home
Go to Book List
Book List
Go to Table of Contents
Contents
Go to Index
Index
Go to Master Index
Master Index
Go to Feedback page
Contact Us

Go to previous page
Previous
Go to next page
Next
View PDF

8 Oracle XML Query Service

This chapter describes how to use Oracle XML Query Service (XQS). The XQS service provides a convenient user model for the retrieval, analysis, integration, and transformation of enterprise data. The following topics are covered:

Introduction to Oracle XML Query Service

This section introduces Oracle XML Query Service, providing a brief overview of XQS and related technologies that it is built upon. This discussion includes the following topics:

What Is XQS?

XQS is an OC4J service built upon XQuery (the XML query language) to provide a simplified, declarative mechanism for creating integrated views of enterprise data.

Generally, without a service such as XQS, XQuery is limited to accessing XML documents. With XQS, you can also retrieve data from non-XML documents, relational databases, and other possibly non-XML enterprise information systems, through access mechanisms such as SOAP or JDBC.

XQS simplifies your programming task. In the planning stages, you need only focus on the design of your XQuery expressions (queries, built-in function calls, or user-defined function calls) and the structure of the data. The details of accessing data sources are determined later, through configuration settings—this is where a binding occurs between your XQuery expressions and the data to be accessed. XQS then does the work of creating external XQuery functions, referred to as XQS functions, used in retrieving the data from the desired sources.

XQS supports ad-hoc queries, which are XQuery expressions passed in at runtime, or XQS views, which are queries you created and saved previously. A view becomes an XQuery function that you can access later by name. (XQuery itself does not yet support the concept of views.) Views enable you to reuse XQuery expressions in building hierarchical queries that are powerful and yet easily maintainable.

XQS offers a variety of client interfaces, enabling you to execute your XQuery expressions through an EJB, a JSP tag library, a Java class, or a Web service.

Technologies Related to XQS

This section offers a glance at technologies that XQS is built upon:


Note:

For introductory tutorials for these and related technologies, you can try the following site (among many others):
http://www.w3schools.com/

A Quick Look at XQuery

XQuery is a declarative language for querying and transforming XML data. You can intelligently query an XML source, using desired criteria, and retrieve and interpret elements and attributes and the data they contain. It is a standard and flexible technology that applies broadly across many and varied kinds of XML sources, including XML databases as well as XML documents. Its role is comparable to the role SQL plays in querying a relational database, with similar functionality.

In addition to querying data, XQuery can transform XML data. In this way, it can be used as a complement or an alternative to XSLT.

In XQuery, the basic construct is an expression, with the data model for expressions being based on XPath 2.0. Each XQuery result is returned as an XML sequence. This is a sequence of zero or more data items, where each item is a scalar value, XML node, or XML document. Type definitions for items are based on the XML Schema standard.

A query may consist of one or more fragments called modules, and a module may consist of a prolog followed by a query body. A prolog is a series of declarations and imports that define the processing environment for the module.

The general model for a query in XQuery is the "for-let-where-order-return" (FLWOR) expression. Here is pseudocode showing an example of what a FLWOR expression could accomplish:

For each department in depts.xml
Let [variable] represent each employee in each department
Where the headcount of employees in a department is at least 10
Order by average salary of department
Return headcount and average salary of each department

XQuery also allows the definition and use of predefined functions to perform queries. For more complex queries, external functions may be provided separately, then declared and invoked from your XQuery definition. External functions may be implemented in a variety of languages, including Java and SQL.

The use of external functions is a critical part of XQS functionality. XQS creates external functions, according to your XQS configuration, to execute the desired queries on your data.


Notes:

  • XQuery 1.0 is an extension of XPath 2.0, so they share the same data model, functions, and syntax. The data model is also common to XSLT 2.0.

  • For details about XQuery, refer to the specification XQuery 1.0: An XML Query Language, available at the following location:

    http://www.w3.org/TR/xquery/
    

The Oracle XQuery Implementation

The Oracle XQuery implementation in Java is an underlying engine for XQS and is provided as part of Oracle XML Query Service. Do not confuse this with the Oracle XQuery implementation that is part of Oracle XML DB in the Oracle Database product, although the two have common origins and common features.

XMLItem Type

Oracle's XQuery implementation uses the type oracle.xml.xqxp.datamodel.XMLItem to represent an individual item in the result XML sequence of a query.

Predefined Namespaces and Prefixes

The following table lists predefined namespaces and prefixes for use with XQuery and XQS.

Table 8-1 Predefined Namespaces and Prefixes

Prefix Namespace Description

ora

http://xmlns.oracle.com/xdb

Oracle XML DB namespace

any user-chosen prefix

urn:oracle.bpel.xq

Default namespace for XQS views in Oracle BPEL environment

local

http://www.w3.org/2003/11/xpath-local-functions

XPath local function declaration namespace

fn

http://www.w3.org/2003/11/xpath-functions

XPath function namespace

xdt

http://www.w3.org/2003/11/xpath-datatypes

XPath datatype namespace

xml

http://www.w3.org/XML/1998/namespace

XML namespace

xs

http://www.w3.org/2001/XMLSchema

XML Schema namespace

xsi

http://www.w3.org/2001/XMLSchema-instance

XML Schema instance namespace


You can use these prefixes in XQuery expressions without first declaring them in the XQuery-expression prolog. You can redefine any of them except xml in the prolog. All of these prefixes except ora and urn are predefined in the XQuery standard.

Oracle XQuery Extension Functions

The Java version of Oracle XQuery includes support for ora extension functions first introduced in the database version, including the following:

  • ora:contains lets you restrict a structural search with a full-text predicate.

  • ora:matches lets you use a regular expression to match text in a string.

  • ora:replace lets you use a regular expression to replace text in a string.

  • ora:sqrt lets you return the square root of a number.

  • ora:view lets you query existing database tables or views inside an XQuery expression, as if they were XML documents. In effect, this function creates XML views over the relational data.

For more information about these functions, refer to the XQuery chapter of the Oracle XML DB Developer's Guide.


Note:

At the time of this release, the W3C XQuery working group had not yet published the XQuery recommendation. Oracle will continue to track the evolution of the XQuery standard, until such time as it becomes a recommendation. During this period, in order to follow the evolution of the XQuery standard, Oracle may be forced to release updates to the XQuery implementation which are not backward compatible with previous releases or patch sets. During this period Oracle does not guarantee any backward compatibility between database releases or patch sets with respect to our XQuery implementation. After the XQuery standard becomes a recommendation, Oracle will produce a release or patch set that includes an implementation of the XQuery recommendation. From that point on, standard Oracle policies with respect to backward compatibility will apply to the Oracle XQuery implementation. See http://www.w3.org for the latest information on the status of XQuery.

Implementation Choices Specified in the XQuery Standard

Implicit time zone support: In XQuery in XQS, the implicit time zone is always assumed to be Z.

Implementation Departures from the XQuery Standard

Boundary condition differences, for +0 and -0: The XQuery standard distinguishes positive zero from negative zero, but XQuery in XQS does not. Both are presented as 0, and they are treated equally.

XQuery Optional Features

There is currently no support for the following optional XQuery features defined by the W3C:

  • Schema Import Feature

  • Schema Validation Feature

  • Module Feature

In addition to these defined optional features, the W3C specification allows an implementation to provide implementation-defined pragmas and extensions. These include the following:

  • Pragmas

  • Must-understand extensions

  • Static-typing extensions

The Oracle implementation does not require any such pragmas or extensions.

Support for XQuery Functions and Operators

XQS supports all of the XQuery functions and operators included in the latest specification with the following exceptions, for which there is no support:

  • XQuery regular-expression functions.

    Use the Oracle extensions for regular-expression operations, instead

  • Functions fn: trace, fn:id, fn:idref, fn:codepoint-equal, fn:prefix-from-QName, fn:doc-available, and fn:collection() (fn:collection() without any argument)

XQuery Functions doc and collection

XQuery built-in functions fn:doc and fn:collection are essentially implementation-defined. XQS supports these functions. Function doc retrieves a file from the local file system that is targeted by its URI argument; it must be a file of well-formed XML data. Function collection is similar, but works on a folder (each file in the folder must contain well-formed XML data).

In the XQS implementation of fn:doc and fn:collection, an argument must be a URL that has the "file" protocol and specifies a path to a file on the local file system, as in this function call:

fn:doc("C:/MyDocuments/XQS/myView.xq")

You can omit the protocol part of the URL, which is "file" by default.

As an alternative to the fn:doc() function, you can use an XQS document function to access a document through any URL that Oracle Application Server supports. For example, to access any XML document through an HTTP protocol, you could define <document-source> with the following configuration:

<document-source>
         <function-name prefix="ns"> genericFile </function-name>
   </document-source>

The XQS function genericFile() can be part of a query expression, as follows:

declare namespace ns = "…"; 
declare function ns:genericFile() external; 
for $i in ns:genericFile("http://www.acme.com/repository/item137560.xml") return ...

Comparing XQS with the XQuery API for Java

The XQuery API for Java (XQJ) is an evolving standard for executing XQuery expressions from Java applications. (Refer to JSR-225.) It is a low-level programmatic interface comparable to JDBC. Because it is not yet a standard, however, XQJ is not yet supported in the Oracle Application Server.

XQS supplies a higher-level API for similar underlying functionality. You can execute XQuery expressions from Java without having to write code to connect to the data source, create XQuery expression objects, and so on.

Why Use XQS?

XQS is versatile. It is useful for Web services as well as Java applications, and for accessing non-XML data as well as XML data.

XQS also relieves you of coding steps such as using the low-level XQJ interface to execute an XQuery expression. The XQS model of data source access through non-programmatic configuration allows faster and more convenient development. Also, registration of the library for the external functions that XQS creates is handled automatically, and namespace assignment is flexible and within your control.

As well as being used to retrieve data, XQS can serve as a convenient mechanism for transforming XML data or joining data from multiple sources.

In addition, XQS offers the following advantages and conveniences:

  • The XQS configuration model enables you to create queries that are independent of the particular data source or XML document you access, making your application more portable. You need only alter your XQS configuration for a different source or document location.

  • Use of the "XQS views" feature allows more convenient hierarchical queries, as well as allowing queries to be shared, reused, and centrally maintained.

  • Through the use of performance optimizations in cooperation with other Oracle Application Server and Oracle Database components, a query executed through XQS is expected to perform at least as well as, and typically better than, the hand-coded XQJ equivalent. XQS itself offers additional performance enhancements, including configurable caching for source data and results, and efficiencies in handling large data sets.

  • XQS simplifies migration between the middle tier and database tier. If a data source outgrows middle-tier capacity, you can typically migrate data to Oracle XDB without modifying or redeploying your middle-tier application. Move your data to the database and update your configuration for that data source as appropriate. Other middle-tier data sources can remain on the middle tier.

Also see "Introduction to XQS Performance and Optimization Features".

Requirements, Limitations, and Special Notes

The XQS implementation has the following requirements, limitations, and special notes:

  • XQS uses the OC4J Java Object Cache for its caching. It requires that the cache be running (automatically starting it if necessary), and requires the presence of the Java Object Cache configuration file. See "Configuring XQS Caching" for additional information about caching.

  • Due primarily to limitations of the current XQuery specification, XQS reads from data sources but cannot write to data sources. You can query data, but not update, insert, or delete data.

  • Within the set of nodes (as defined by the XML data model) returned by a function call, each node has a unique identity. But if a function is called more than once in a query, XQS does not guarantee the uniqueness of node identities across the different result sets. Because of this, some queries based on node identity may produce nondeterministic results. As an example, consider the following queries, Q1 and Q2:

    (: Q1 :)
    declare namespace xqs="http://xmlns.oracle.com/ias/xqs";
    declare function xqs:a() external;
    let $x := xqs:a()
    return $x/b is $x/b
    
    

    Q1 will always return true, given that the node identity test is on nodes from the same function call.

    (: Q2 :)
    declare namespace xqs="http://xmlns.oracle.com/ias/xqs";
    declare function xqs:a() external;
    xqs:a()/b is xqs:a()/b
    
    

    Q2 may return true or false, depending on certain performance optimization settings.

Overview of XQS Features and Functionality

This section introduces important XQS features. Further details are provided later in the chapter.

XQS Data Source Support

As noted previously, XQS supports several different kinds of data sources. This section covers the following related topics:

Supported Categories of Data Sources

In XQS, data sources requiring a variety of access protocols can be described through WSDL documents because of XQS support for the popular Apache Web Services Invocation Framework (WSIF), an extension of the Web service mechanism behind SOAP and HTTP to include any custom invocation protocols. Because of this mechanism, XQS supports WSDL-based sources other than SOAP-based Web services. XQS also supports access to relational databases through JDBC by using the mechanism of XQS views written in SQL.

In all, XQS supports the following categories of data sources, with special features to access various kinds of sources through a SQL-based view or a WSDL document.

  • Document: Access files or, more generally, any URL-based input streams that contain XML documents. This is similar to the functionality of the built-in XQuery function fn:doc(). XQS supports the Oracle Data Definition Description Language (D3L) translator plug-ins to convert non-XML data to XML, so non-XML files are supported as well.

  • XQS view: Run a previously stored query (similar in concept to database stored procedures). XQS locates the query, binds any external variables, and executes the query.

  • SQL-based XQS views: Access tables, views, PL/SQL stored procedures, or Java stored procedures in a relational database. This is accomplished by connecting to a database through JDBC during execution of the SQL-based XQS view. If you are working with Oracle XML database, you can use an SQL-based XQS view to select XML type values directly from the database. See "Preparing to Use a Database Source (SQL-Based XQS View)" for detailed information.

  • WSDL source with SOAP binding: Access a resource through a Web service. You must provide a WSDL document, with a SOAP binding, to describe the Web service operations and the data source.

  • WSDL source with Java or EJB binding: Access a resource through any custom Java class or EJB that returns XML data. This is accomplished through the WSIF provider for Java or WSIF provider for EJB. You must implement the class or EJB and provide a WSDL document with a Java or EJB binding, specifying the class name or EJB name and any argument types.

A WSDL document that you provide for any of the WSDL sources will describe a set of callable operations and provide specifics for connecting to the source, using the appropriate binding. Your XQS configuration will reference a name for each operation, and point to the WSDL for the description of the operation. The WSDL must have a working URL, which you specify in your XQS configuration. XQS will go to that URL to fetch the WSDL. Also note that XQS enables you to use a WSDL URL as an XQuery namespace, and to treat individual operations of a WSDL port as local names in that namespace.

Data Source Access Through XQuery Functions

Access of your data sources and execution of your operations are accomplished through external XQuery functions, referred to as "XQS functions" (introduced earlier), that XQS automatically creates and invokes for you based on your XQS configuration. You specify the desired name and namespace of the function in your configuration, along with other relevant items (input parameters, for example). When you use a data source in a query, you must declare the associated XQS function as an external function in your XQuery prolog.

A namespace corresponds to a function library containing function objects. Each function object corresponds to an operation. For a WSDL source with SOAP binding, for example, there is a function object for each operation in the WSDL document. For an XQS view source, each function object corresponds to a different stored query.

What Do Data Source Function Objects Do?

Each function object created by XQS is instantiated according to your XQS configuration, and performs the following basic tasks:

  1. Accepts input arguments passed from the XQuery engine. Permissible input types are according to what is allowable in an XML sequence; namely, primitive Java types and XML nodes. XQS cannot perform Java object-to-XML mapping, but you can perform mapping prior to the query, such as through Oracle TopLink.

  2. Invokes the query against the underlying data source. XQS maps the function name to the corresponding XQS configuration element, then finds the connection information for the data source and creates the connection.

  3. Receives and packages results. XQS synchronously receives results from the data source, in XML form, then packages the results into an XML sequence.

  4. Processes any errors (such as problems accessing a data source, for example, or type incompatibilities) and returns error information according to your error-handling configuration.

Overview of Preparing Data Sources

For most data sources you can use with XQS, there are necessary preparation steps. For example:

  • To use a non-XML document source, you must prepare to use the conversion tool, Oracle D3L, that XQS supplies. Preparation includes providing a D3L schema file with instructions about the data format.

  • To use an XQS view, you must consider the data input and return types, design the query, save it as an .xq file, and decide where to place it.

  • To use a WSDL source with any of the supported bindings, you must provide (in some cases, create) an appropriate WSDL document.

See "How to Prepare to Use Your Data Sources" for details.

Introduction to XQS Configuration and the Configuration File

The XQS configuration file is xqs-config.xml, which XQS looks for in the xqs-resources.jar file (created by the OC4J packaging utility) at the top level of the application EAR file. Use the configuration file to specify information about XQS functions and data sources.

The top-level elements in xqs-config.xml are as follows:

  • <document-source> to access data from a document, including either XML or non-XML files

  • <xqsview-source> to use an XQS view

  • <wsdl-source> for any data source involving a user-provided WSDL document

XQS reads information from the configuration file and uses that information to populate the XQS function objects that access the data sources.

You do not have to restart OC4J when you update configuration, but you must redeploy the application. (See the Oracle Containers for J2EE Deployment Guide for information.)

See "How to Configure Your XQS Functions" for additional information.


Note:

In the Oracle Application Server, there are not yet any pages for XQS configuration in the Oracle Enterprise Manager 10g Application Server Control Console. You can manage your XQS configuration directly in the xqs-config.xml file.

Introduction to XQS Client Interfaces

XQS supports the following client interfaces for implementing your XQuery functionality. See "How to Develop Your Application Code: Using the XQS Client Interfaces" for usage information and examples for each of these interfaces.


Note:

When you use any of the XQS client APIs for a query, the query execution defines the results, but does not necessarily put all the results into memory immediately. A set of results that is immediately and fully stored into memory is said to be materialized, whereas a set of results accessed one at a time (or several at a time, with batching) through an implicit cursor, using some sort of "next item" functionality, is said to be nonmaterialized. With nonmaterialized results, there is no guarantee as to when results are retrieved and written to memory. Any "next item" call may trigger the evaluation of the XQuery expression to produce the next result item.

As noted in the descriptions that follow, XQS client APIs allow you the choice of using stateless client objects, with materialized results, or using stateful client objects, with nonmaterialized results.

These concepts are discussed in further detail, and with strategic considerations, in "Stateful Versus Stateless Clients".


  • Client API: XQS provides a general-purpose Java interface, XQSFacadeI, that you can use for a Java implementation of desired XQuery functionality. This interface is based on the facade design pattern, shielding you from details and complexities of the underlying XQS functionality. Use the appropriate execute method to pass in an ad-hoc query or XQS view name and any bind parameters. In either case, use the "get next item" method to process the results. After running the query, an XQSFacadeI instance wraps an XML result sequence and maintains its current state. It is up to the client whether to retrieve and process items from the sequence incrementally (a stateful approach), or to retrieve and process all items from the sequence at once, after which the underlying data source resources may be released (a stateless approach).


    Note:

    The XQSFacadeI interface is also used behind the scenes for the EJB client API and JSP tag library.

  • Oracle BPEL XQuery function: You can use XQuery and XQS in an Oracle BPEL PM environment through the Oracle BPEL XPath function that executes XQueries. Oracle BPEL PM provides a Java class for BPEL users (com.collaxa.cube.xml.xpath.functions.xml. GetElementFromXQueryFunction). You can register this class as an XPath function with a BPEL process and pass it the name of one of the XQueries, which you packaged with the BPEL process for execution.

  • EJB client API: The EJB client API provides a way to access your application through session beans, either remotely (through RMI) or locally. XQS supports the use of either stateful or stateless session beans. Stateless beans minimize calls to the EJB, while stateful beans are preferable if memory usage is a concern. In either case, you provide the ad-hoc query or XQS view name, along with any bind parameters, in the appropriate "execute" method. For a stateful session bean, you use the "get next item" method to process the results. For a stateless session bean, the sequence is always materialized and is returned by the "execute" method.

  • JSP tag library: The JSP tag library provides a way to access your application through HTTP. XQS provides JSP tags for either stateful or stateless access. You provide the ad-hoc query or XQS view name using an "execute" or "executeCursor" tag. Which tag to use depends on whether you want stateful or stateless access. There is a nested "parameter" tag for specifying bind parameters. For stateful access, you use the "next" tag associated with the "executeCursor" tag to process the results. For stateless access, the sequence is always materialized and is returned by the "execute" tag. Results can be returned as a JSP output stream, a DOM document, or an array of Java Object instances (according to attribute settings of the "execute" or "executeCursor" tag).

  • XQS view Web service: When you use an XQS view, you can optionally have XQS add an operation to a WSDL document that it creates, to expose the view as a Web service operation. (This is accomplished as part of the configuration for an XQS view.) You can then implement a client for this as you would for any other Web service.


Note:

Also be aware of the XQS QueryParameterI interface. To use queries with external binds for the Java client API or EJB client API, you must create an array of QueryParameterI objects for the bind values. See "XQS QueryParameterI Reference" for reference information. (This interface is also used behind the scenes for the JSP client interface.)

Introduction to OC4JPackager

OC4JPackager, provided with XQS, is a command-line Java tool that packages XQS-related files with a J2EE or Web application to allow the application to use XQS functionality.

In a typical scenario, you would write a Web application that calls XQS through one of the XQS client APIs (the XQSFacadeI interface, EJB client API, or JSP tag library). You would also create an XQS configuration file, xqs-config.xml, that points to the relevant data sources and XQS views, and choose an XQS repository—the directory where your views are located. Then you would bundle your application, XQS configuration file, and XQS repository into an EAR file, which you then deploy.

Given instructions through its command-line parameters, OC4JPackager will complete the step of bundling everything for you. Specifically, it does the following:

  1. Bundles xqs-config.xml and all XQS repository files into a file called xqs-resources.jar.

  2. Opens each archive associated with your application (such as WAR files and EJB JAR files) and modifies the Class-Path attribute in the manifest (MANIFEST.MF) to include xqs-resources.jar.

  3. Bundles an EAR archive that consists of all your application archive files plus xqs-resources.jar.

  4. Creates or modifies (as applicable) the orion-application.xml file in the EAR archive to add xqs-resources.jar to the list of libraries accessible by all components of the EAR.

When you run OC4JPackager, you specify a directory that contains one of the following:

  • An existing EAR file, which OC4JPackager will unbundle and rebuild

  • An existing set of J2EE modules such as WAR and EJB JAR files, which OC4JPackager will bundle into a new EAR.

For an XQS view that you want to expose as a Web service operation, OC4JPackager performs additional tasks, delegating invocation of the Web service operation to the XQS view. The operation is added to a WSDL document that is automatically generated. For more information see "OC4JPackager Additional Output to Expose XQS Views As Web Service Operations".

For more information about OC4JPackager in general, see "How to Use OC4JPackager to Package Your XQS Application" and "OC4JPackager Reference".

Security for XQS Applications

XQS itself does not add any layers of security. In this way, it is essentially like any J2EE application. Security is provided by OC4J through standard Web and J2EE security features that you must use, as appropriate for the type of XQS client you are using and the type of data source you are accessing.

For example, if you are using a SQL-based XQS view with a SQL binding, use database security features. If you are using the XQS EJB client interface, use standard EJB security. If you are using the XQS JSP tag library, use standard authentication for an HTTP connection. And so on.

Introduction to XQS Performance and Optimization Features

XQS offers the following features to improve performance:

  • Caching: XQS can cache the results of XQS view execution, or cache XML data from data sources for use in future queries. This improves performance, particularly for situations where data sources, such as external Web services, may require significant time to access. Caching is also important when accessing asynchronous sources. You can specify expiration and invalidation settings for cached data, or optionally disable caching entirely, through your XQS configuration.

  • Handling of large data sets: XQS has features to minimize the chance of running out of system memory when you access very large data sets, such as dozens of megabytes or more. In such situations, XQS will materialize the results partially, as the data is needed, staying within a fixed amount of memory usage (a "working unit" approach). You have the option of returning data items one by one.

  • Scalability: XQS efficiently streams inputs to the XQuery engine, allows sharing and reuse of cached resources (such as parsed WSDL documents), and can use non-materialized result sequences as appropriate for scalability. You can control these behaviors through your XQS configuration.

See "Using XQS Performance Features" for more information.


Note:

While XQS works in close conjunction with the Oracle XQuery engine and XDK to optimize data flow, XQS does not optimize the queries.

Introduction to XQS Error Handling

An XQS application may encounter problems related to XQS external functions and the underlying data sources during execution, such as problems converting input parameters to types expected by the data source, or problems converting data returned by the data source to XML. In addition, the data source may be unavailable or may return an error. The default behavior of XQS is to raise an XQuery dynamic error in these situations, which stops execution of a query, with no results being returned.

Alternatively, an XQS configuration attribute (onError) enables you to choose less severe behaviors, allowing XQS to continue so you can obtain additional information about any errors that occurred. Three error-handling modes are available:

  • dynamicError (default)

  • emptySequence

  • errorMessage

With emptySequence or errorMessage mode, if an error is encountered during execution of an XQS external function for which this mode has been set, the error does not terminate query execution, and will be retained by XQS for later retrieval if desired. XQS returns an empty XML sequence (for emptySequence mode) or a one-item XML sequence consisting of an error message (for errorMessage mode). In errorMessage mode, you can preconfigure a fixed error message in your XQS configuration, or you can have the message be whatever is returned by the data source.

Information about "suppressed" errors from XQS external functions is returned by XQS in an iterator of XQSErrorI objects.

XQS applies special handling only to errors inside an XQS function. A regular XQuery error, such as a syntax error or type mismatch, terminates query execution regardless of the XQS error mode.

You configure the XQS error mode for each XQS function individually. The error mode for one function does not have any affect on the behavior of other XQS functions in the same query.

See "Using XQS Error Handling Modes and APIs" for more information.

Summary of the Main Steps in Using XQS

The following are the key steps in using XQS. Links are provided to the sections that cover each step in detail.

  1. Prepare your data sources as necessary. For a document source, for example, this would include any setup to convert from non-XML to XML. For XQS views, this includes defining and saving the queries. Some access of sources, such as databases, also requires special setup. See "How to Prepare to Use Your Data Sources".

  2. Configure XQS. Use the xqs-config.xml file to specify and configure data sources to be accessed and queries to be executed, and to create mappings to the XQS functions that represent the data sources for the queries. See "How to Configure Your XQS Functions".

  3. Design your queries. See "How to Design Your Queries".

  4. Develop your application. This primarily involves using one of the APIs that XQS provides to execute your XQuery expressions, and processing the XML results that are returned. See "How to Develop Your Application Code: Using the XQS Client Interfaces".

  5. Package and deploy your application. Use the packager supplied with XQS. See "How to Use OC4JPackager to Package Your XQS Application".


Note:

This is a simplification. Typically, you cannot actually go through the steps in a modular, sequential manner, especially with multiple sources that may include XQS views. The process is iterative. For example, you could start by preparing a database source and then design a query for it. Then you may want to persist the query as an XQS view—in other words, prepare an XQS view source. Then you may design another query that uses the view.

How to Prepare to Use Your Data Sources

For most data sources you want to use with XQS, there are necessary preparation steps. This section covers the following topics:

Preparing to Use a Non-XML Document Source

Some documents do not use XML as their native message format, instead using native formats such as structured records of bytes and characters. Examples of this are Excel comma-separated-values (CSV) files. For non-XML data to be understandable for use with XQS and XQuery, it must follow a predefined, structured set of rules so that XQS can use an appropriate conversion tool. Data in such a structured format can be processed so that it can be retrieved and transformed into an XML format for your application.

For use of non-XML documents, the XQS implementation supports the Oracle Data Definition Description Language (D3L). Prepare to use a non-XML document source with XQS by taking the following steps:

  1. Ensure that the non-XML data is compatible with the D3L conversion mechanism.

  2. Provide a schema file that gives instructions to D3L about the data format, so D3L can parse and convert the data.

  3. Configure XQS to use D3L, specifying the name and location of the schema file.

The following sections provide an overview of D3L and its usage:


Note:

See the Oracle Application Server Integration InterConnect User's Guide for details about D3L features.

What Is D3L?

D3L describes the structure that must be followed by the native, non-XML format of a document to allow processing by certain Oracle middle-tier components—in general, by OracleAS Integration InterConnect; for purposes of this document, by XQS.

D3L supplies the following:

  • An XML-based data description language that describes the format of native files, such as the record layout of binary, string, structured, and sequence data

  • A translation engine that uses the instructions from a D3L schema file to translate the native format file contents

D3L schema files must comply with the syntax defined by the D3L document type definition (DTD). You specify the D3L schema file to use through your XQS configuration.


Important:

To use D3L, the number of fields in the underlying native format data must be fixed and known. D3L is not suitable for arbitrarily structured data (such as regular XML), name-value pair data, or conditional data structures that require token look-aheads to parse.

D3L Schema Files

A D3L schema file describes data types, formats, and delimiters so that the D3L translation engine can parse the data and convert it to XML. The schema file must conform to the specifications of d3l.dtd.

Refer to the Oracle Application Server Integration InterConnect User's Guide for details about D3L schema files and how to create them, but here is a fragment to give you a general idea of their appearance:

<?xml version="1.0" encoding="US-ASCII"?>
<!DOCTYPE message SYSTEM "d3l.dtd">
<message name="replyFlight" type="BookingReplyType" object="Booking"
         header="D3L-Header" value="replyOptions">
   <unsigned4 id="u4" />
   <unsigned2 id="u2" />
   <struct id="DateTimeRecord">
      <field name="DateInfo">
         <date format="MMDDYY">
            <pfxstring id="datstr" length="u4" />
         </date>
      </field>
      <field name="TimeHour"><limstring delimiter="*" /></field>
      <field name="TimeMinute"><limstring delimiter="*" /></field>
   </struct>
...
</message>

Configuring XQS to Use D3L

To have XQS use the D3L conversion mechanism for a non-XML document source:

  1. Use the <XMLTranslate> subelement of <document-source> to direct XQS to use D3L. (In the future, other tools may be supported as well, and specified in the same way.)

  2. Use the <schema-file> subelement of <XMLTranslate> to specify the schema file for D3L to use in parsing the data.

Here is the XQS configuration to use a D3L schema file named PersonalInfoD3L.xml:

<document-source ... >
   ...
   <XMLTranslate method="D3L">
      <schema-file>http://host:port/xqs/PersonalInfoD3L.xml</schema-file>
   </XMLTranslate>
   ...
</document-source>

Notes:


Preparing to Use an XQS View

As noted earlier, an XQS view is a query that is stored for future use. XQS treats the view itself as a source, and you configure it through an <xqsview-source> element. To prepare to use a query as an XQS view, do the following:

  1. Consider any input parameters that the query will require. You can specify a parameter for an XQS view by declaring it as an external variable in the XQuery prolog.

  2. Design the query, including external variable declarations for any input parameters, and save it as an .xq file. (Also see "How to Design Your Queries".)

  3. Consider where you will place the .xq file. Your location for .xq files is referred to as the XQS repository. You can specify a location through your XQS configuration (using the <repository> element), or you can use a location you specify through the -repository option when you run OC4JPackager.

  4. Consider whether to expose the XQS view as a Web service operation. Do this through the WSDLvisibility attribute of the <xqsview-source> element in your XQS configuration. This results in the view being included as an operation in a Web service that XQS adds to your application. If you do expose the view as a Web service operation, be aware of the XML output type—we advise that you reflect that type in the <output-element> subelement of <xqsview-source> in your configuration. (Also see "Using an XQS View Exposed as a Web Service Operation" for additional information.)

Following is an XQuery expression that we will use for an XQS view. It accepts the external variable loc and passes it through to a function readFile that reads purchase order data from a file. You can use any desired .xq file name to save it, and specify that name in your XQS configuration. You will also have to specify a desired name for the XQS function that XQS will implement to execute the view. The file name and function name are distinct, but you can use the function name as the base name of the file by default if you want.

declare variable $loc external;
declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare function xqs:readFile($l as xs:string) external;
for $po in xqs:readFile($loc)//po return $po//total

In your XQS configuration, under the <xqsview-source> element, you will typically use at least the following:

  • The WSDLvisibility attribute if you want to expose the view as a Web service operation, and then the <output-element> subelement if you do expose the view

  • The <function-name> subelement to specify the desired name of the XQS function for the view

  • The <input-parameters> subelement and its subelements to specify external variables that correspond to input parameters of the XQS function (loc in the preceding example)

  • The <queryName> subelement to specify the name of the .xq file containing the view (unless you use a base file name that matches the XQS function name)

  • The <repository> subelement to specify the location of the .xq file (not necessary if the file is in the location specified through the -repository option when you run OC4JPackager)


Notes:


Preparing to Use a Database Source (SQL-Based XQS View)

SQL-based XQS views enable you to use XQuery on data retrieved from a relational database (including XML support). The data is retrieved through JDBC. A SQL-based XQS view is a stored query written in SQL language. XQS treats the SQL-based view itself as a source, which is configured through an <xqsview-source> element.

Complete the following procedure to prepare the SQL query for use as an XQS view:

  1. Determine the database and the schema that you intend to use for the SQL query. Find or define the appropriate <managed-data-source> or <data-source> element in the OC4J data-sources.xml configuration file that represents that connection. Use the JNDI name of that data source as a reference in the <xqsview-source> configuration element. Specifically, put the JNDI name of the data source into the <dataSource> sub-element of <xqsview-source> element. XQS uses the data source to open a JDBC connection. For XQS views based on SQL queries, the <dataSource> configuration element is mandatory.

  2. Consider any input parameters that the query requires. For the query written in the SQL language, use positional bind variables - :1, :2, :3, and so on - as query parameters.

  3. Determine the database objects (tables, views, stored procedures, or PL/SQL packages) that are required. Then, design the query and include positional bind variables for any input parameters. XQS only executes SQL query statements (that is, a SELECT statement). You may invoke Java or PL/SQL stored procedures in the query. The SQL statement cannot be an INSERT or UPDATE, or any of the Data Definition Language (DDL) statements. Save the query as a .sql file.

  4. Determine whether the database query returns data in the relational (tabular) or XML form. If you are working with the Oracle XML database and the query result is of type XMLType, XQS takes the result as is and does not attempt any conversion. To specify that the result is already in XML form, set the SQLResultType attribute to XMLType (XQS does not analyze the query on its own, because it requires additional round-trip to the database and degrades performance).

    If the database query returns data in the relational form, the SQLResultType attribute must be set to relational, which is also the default. In this case, XQS utilize the Oracle XML-SQL Utility (XSU) to convert the relational result to XML. XSU converts every row in the result set into a an XML element. The default element name is ROW. The default element can be customized by setting the rowTag attribute of the <xqsview-source> configuration element. Row elements can be numbered with an attribute of your choice. By default, XSU does not assign numbers to row elements. If you want row numbering, specify the rowIdAttr attribute of the <xqsview-source> configuration element. The value of rowIdAttr attribute is the name of the numbering attribute in the result row element. Rows will be numbered starting from 1, as 1, 2, 3, …

    XSU transforms each column in the relational result into an element nested in the row element. The element tag is taken from the name of the column. Column element names cannot be customized. However, a column may be assigned an alias name when creating a relational result in the SQL query.

    As an example, consider the following SQL query that is executed in the default Oracle Order Entry schema OE:

    select PRODUCT_ID,PRODUCT_NAME,PRODUCT_STATUS,LIST_PRICE from
    PRODUCT_INFORMATION where product_id < :1
    
    

    with the rowTag="product" and rowIdAttr="record_num" attributes set, the result of this SQL-based view execution might look like this:

    <product record_num="1">
       <product_id>1726<product_id>
       <product_name>LCD Monitor 11/PM<product_name>
       <product_status>under development<product_status>
       <list_price>259<list_price>
    </product>
    <product record_num="2">
       <product_id>1729<product_id>
       <product_name>Chemicals - RCP<product_name>
       <product_status>orderable<product_status>
       <list_price>80<list_price>
    </product>
    
    

    Take into consideration the XML transformation previously described when designing an SQL query.

  5. Consider where the .sql file is saved. The location for the .sql files is referred to as the XQS repository. A location is specified through the view source XQS configuration (using the <repository> element), or specify the location through the -repository option when you run the OC4JPackager utility. Multiple .xq and .sql files can be saved to the same repository.

    The select statement in the preceding example is the expression that is used for a SQL-based XQS view. It accepts the SQL bind variable :1, executes the SQL query and returns results in the form of an XML sequence of elements. The .sql file can be saved with any name and specified in the XQS configuration. The name of the XQS view function that executes the view is getProductInfo. The .sql file name and function name are distinct; however, the function name can be the same as the base name of the file by default.

The following elements and attributes are typically used in the XQS configuration for a SQL-based XQS view. The elements are subelements of the <xqsview-source> element.

  • The <function-name> subelement is used to specify the desired name of the XQS function for the view.The <dataSource> subelement is used to specify the JNDI name of the data source that is defined in the data-sources.xml configuration file. The data source is used to establish a JDBC connection. This subelement is mandatory for the SQL-based views.The <input-parameters> subelement and its <part> subelements are used to specify bind variables that correspond to input parameters of the XQS function. Since SQL bind variables are bound by position, in this case the name attribute of the <part> subelement is ignored, but the position attribute is important (as seen in the preceding example,:1 will have position="1").The fetchSize attribute of the <xqsview-source> element is used to set the number of rows to be transferred from the database in one round-trip. The default is 1. This attribute is translated into a call to the setFetchSize method of java.sql.PreparedStatement. The setFetchSize parameter in JDBC (and, therefore, the fetchSize attribute in XQS) is only a hint: it is not binding.The <queryName> subelement is used to specify the name of the .sql file containing the SQL query (unless a base file name that matches the XQS function name is used).The <repository> subelement is used to specify the location of the .sql file (not necessary if the file is in the location specified through the -repository option when using the OC4JPackager utility).

The following attributes of the <xqsview-source> element are optional. If the attributes are not set, the default values are used:

  • fetchSize="1"

  • XMLFormat="XSU"

  • rowTag="ROW"

  • rowIdAttr=""

  • SQLResultType="relational"


Note:

For a detailed reference of XQS configuration elements and attributes, see "XQS Configuration File Reference". In addition, see "Configuring an XQS Function that Uses an XQS View".

Preparing to Use a WSDL Source with SOAP Binding

To access a data source through a Web service operation, you must provide a WSDL document for the Web service and specify the location of the WSDL in your XQS configuration. One XQS view function corresponds to one Web service operation that XQS will implement.

Examine the WSDL. You will use a <wsdl-source> element and its subelements in the XQS configuration file to configure the XQS function, with configuration settings (some optional) corresponding to WSDL entries as follows:

  • The WSDL operation corresponds to an <operation> element in the XQS configuration.

  • For WSDL input messages, each input message part corresponds to a <part> subelement of <input-parameters>.

  • The applicable WSDL service corresponds to a <service> element.

  • The applicable WSDL port corresponds to a <port> element.

  • The applicable WSDL port type corresponds to a <portType> element.

In addition, consider how the WSDL document may be accessed by XQS, and specify this location using the <wsdlURL> element.


Notes:


Preparing to Use a Custom Class or EJB (WSDL Source with Java or EJB Binding)

You can access a data source through a custom Java class or EJB by using the WSIF provider for Java or the WSIF provider for EJB. XQS does nothing special in this area; this is open technology from the Apache Foundation. You must do the following:

  • Implement a custom Java class or EJB that returns XML data that you can then query.

  • Create a WSDL document with Java or EJB binding (as appropriate) to define the desired operations.

  • Consider any XML-Java type mapping you will require.

See "Preparing to Use a WSDL Source with SOAP Binding" for general WSDL considerations for your XQS configuration.

Refer to the Oracle Application Server Web Services Developer's Guide for information about how to implement the class or bean and the Oracle Application Server Advanced Web Services Developer's Guide for information on the WSIF providers for Java and EJB.

Here is a sample fragment from a WSDL document with Java binding. With this, you can invoke the Java method readEntry(), for example, by its operation name. Note that a WSDL <format:typeMapping> specification corresponds to a <typeMap> element in the XQS configuration.

< definitions>
  ...
  <binding name="JavaBinding" type="tns:AddressBook">
    <java:binding /> 
    <format:typeMapping encoding="Java" style="Java">
       <format:typeMap typeName="typens:address"
             formatType = "localjava.client.stub.addressbook.wsiftypes.Address" /> 
       <format:typeMap typeName="xsd:string"
             formatType="java.lang.String" /> 
    </format:typeMapping>
    <operation name="readEntry">
        <java:operation methodName="readEntry" 
              parameterOrder = "name" 
              methodType = "instance" /> 
        <input name="ReadEntryWholeNameRequest" /> 
    <operation name="readAllMatchingEntries">
     ...
    </operation>
  </binding>
  <service name="AddressBookService">
     <port name="JavaPort" binding="tns:JavaBinding">
        <java:address 
          className = "localjava.service.AddressBookImpl" /> 
     </port>
  </service>
  ...
</definitions>

How to Configure Your XQS Functions

There must be an entry in the XQS configuration for each XQuery external function used in any XQuery expression in your application—in other words, for each XQS function that XQS will implement—that specifies details including the desired name of the XQS function that will be used in the query, the data source to access, and any input parameters. There are three basic configuration categories: for a document source, an XQS view, or a WSDL source. And there are three corresponding high-level configuration elements: <document-source>, <xqsview-source>, and <wsdl-source>.

This section covers the following topics:

See "Introduction to XQS Configuration and the Configuration File" for a related overview of the XQS configuration file.

See "XQS Configuration File Reference" for reference information about the configuration elements discussed here.

Configuring an XQS Function that Accesses a Document Source

This section discusses how to configure an XQS function that accesses a document source, concluding with examples. Elements mentioned here are subelements of the <document-source> element. For additional information, see the reference section "<document-source>", which includes links to information about all the subelements.

Always Required

At a minimum, you must configure the following element for a document source:

  • <function-name>: Through this element, specify the qualified name you want to use for the XQS function that XQS implements to access the document source. The element value is the local name, and there are attributes for the namespace (either namespace or prefix, as discussed in "<function-name>"). Your XQuery prolog must use the same name when declaring the XQS function as an XQuery external function.

    Here is a sample configuration:

    <document-source ... >
       <function-name namespace="http://xmlns.oracle.com/ias/xqs">
          myFileSource
       </function-name>
       ...
    </document-source>
    
    

And here is a corresponding XQuery declaration and usage:

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare function xqs:myFileSource() external;
for $po in xqs:myFileSource()//po
return $po

Optional or Sometimes Required

The following elements are sometimes necessary or appropriate for a document source:

  • <documentURL>: Use this element to specify the URL of the document source. Here is an example:

    <document-source ... >
       ...
       <documentURL>
          http://host:port/xqsdemos/Repository/pos-2KB.xml
       </documentURL>
       ...
    </document-source>
    

    Important:

    For your specification of the document URL, be aware that if the document is on the local file system, then using file:// protocol to specify the absolute path to the file, instead of using http:// protocol, will give you faster data retrieval.

    If you provide a <documentURL> element, then you implicitly specify that your XQS function takes no arguments. Alternatively, you can omit <documentURL>, in which case you must pass the URL in to the XQS function at runtime, as in the following example. In this case, the function must be declared in XQuery to have one parameter for the URL.

    declare namespace xqs = "http://xmlns.oracle.com/ias/xqs"; 
    declare function xqs:myFileSource($bind as xs:string) external;
    for $po in xqs:myFileSource
              ("http://host:port/xqsdemos/Repository/pos-2KB.xml")//po
    return  $po
    
    
  • <output-element>: You can use this subelement to specify the qualified name of the XML element or output type (either a simple type or a complex type) for data that is returned. This is not always required, but XQS can use the information for type checking. Here is an example:

    <document-source ... >
       ...
       <output-element namespace="http://xmlns.oracle.com/ias/xqs/CustomerDemo"
                    location="http://host:port/xqsdemos/Customers.xsd"> type=Customers
       </output-element>
       ...
    </document-source>
    
    

    For an <xqsview-source> element that defines <output-element>, the <output-element> subelement is required in every XQS function that defines an errorMessage error-handling option in the underlying query, or in a query that is nested through the use of another <xqsview-source> function. For more information about this requirement, see "Using XQS Error Handling Modes and APIs".

  • <XMLTranslate>: For a non-XML document source, use this element to specify the conversion tool to use and to provide any information the tool needs. Currently only D3L is supported, which requires a D3L schema file to be specified through the <schema-file> subelement. See "Preparing to Use a Non-XML Document Source" for information about D3L.

    Here is an example:

    <document-source ... >
       ...
       <XMLTranslate method="D3L">
          <schema-file>
             http://host:port/xqsdemos/paymentInfoD3L.xml
          </schema-file>
       </XMLTranslate>
       ...
    </document-source>
    

Performance and Error Handling

You can set up error-handling and specify the use of performance features such as caching or special processing of large data sets. This would involve the <document-source> attributes isCached, largeData, and onError, and subelements <cache-properties> and <error-message>. Configuring these features is not discussed here. Refer to "Using XQS Error Handling Modes and APIs" and "Using XQS Performance Features".

Examples

These examples use default settings for caching, large data, and error handling, which is equivalent to <document-source> attribute settings of isCached="false", largeData="false", and onError="dynamicError".

The following example is for an XML document source that resides in a fixed location:

<document-source>
   <function-name namespace="http://xmlns.oracle.com/ias/xqs">
      myFileSource
   </function-name>
   <documentURL>
      http://host:port/xqsdemos/Repository/pos-2KB.xml
   </documentURL>
</document-source>

The following example is for a document source in non-XML format, using the D3L conversion tool and paymentInfoD3L.xml D3L schema file:

<document-source>
   <function-name prefix="xqs">
      paymentStatusInfo
   </function-name>
   <documentURL>http://host:port/xqsdemos/paymentInfo.csv</documentURL>
   <XMLTranslate method="D3L">
      <schema-file>
         http://host:port/xqsdemos/paymentInfoD3L.xml
      </schema-file>
   </XMLTranslate>
</document-source>

Configuring an XQS Function that Uses an XQS View

This section discusses how to configure an XQS function that uses an XQS view, concluding with an example. Elements mentioned here are subelements of the <xqsview-source> element. For additional information, see the reference section "<xqsview-source>", which includes links to information about all the subelements.

For preliminary steps, such as creating the XQS view that you will use, see "Preparing to Use an XQS View".

WSDLvisibility Setting

You can use the <xqsview-source> attribute setting WSDLvisibility="true" to expose an XQS view as a Web service operation. XQS adds the operation to the WSDL that it generates. The Web service operation is made part of the Web service of that application. The use of WSDLvisibility attribute is optional and the default value is false.


Note:

In order to minimize the risk of SQL injection using bind variables, XQS does not allow SQL-based XQS views to be exposed as Web service operations. Any user input should be screened and validated by the application before passing it to a SQL-based XQS view function and, thus, to a SQL query. If WSDLVisibility attribute is set to true for an SQL-based view, XQS issues a warning and ignores the setting.

For more information about exposing an XQS view as a Web service, see "OC4JPackager Additional Output to Expose XQS Views As Web Service Operations".

Always Required

For ensuing discussion, assume the following example has been saved as an XQS view in mytotals.xq. It uses a function that reads from a file, taking the input parameter loc (a string variable indicating a file location) and passing it through to the function, then returns an integer total:

declare variable $loc external;
declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare function xqs:readFile($l as xs:string) as xs:int external;
for $po in xqs:readFile($loc)//po return $po//total

At a minimum, you must configure the following elements to use an XQS view:

  • <function-name>: Through this element, specify the qualified name you want to use for the XQS function that XQS implements to execute the view. The element value is the local name, and there are attributes for the namespace (either namespace or prefix, as discussed in "<function-name>"). If you use this function in a query (as opposed to using the view directly in an executeView() call), then you must declare the XQS function as an XQuery external function, using the function name specified in the <function-name> element.

    Here is a sample configuration:

    <xqsview-source ... >
       <function-name namespace="http://xmlns.oracle.com/ias/xqs">
          totals
       </function-name>
       ...
    </xqsview-source>
    
    
  • <input-parameters>: If an XQS view takes external variables (bind variables in the case of a SQL-based view), then the function implemented by XQS must take an input parameter for each external or bind variable in the view. XQS will assign function argument values to external or bind variables before executing the query. Use the <input-parameters> element to configure input parameters, with a <part> subelement for each parameter. Note that this element is always required for an XQS view; use an empty element if there are no input parameters:

    <xqsview-source ... >
       ...
       <input-parameters/>
       ...
    </xqsview-source>
    
    

    Following is an example with one input parameter being bound to an external string variable named loc. Input parameters for an XQS view can optionally include type information using a <schema-type> or <xquery-sequence> element. Assume for the following example that the xs prefix has been set to correspond to the XMLSchema namespace. (See reference documentation later in this chapter for information about the <input-parameters>, <part>, <schema-type>, and <xquery-sequence> elements.)

    <xqsview-source ... >
       ...
       <input-parameters type-match="none" >
          <part position="1" name="loc">
             <schema-type prefix="xs">string</schema-type>
          </part>
       </input-parameters>
       ...
    </xqsview-source>
    
    

SQL-based views bind variables are denoted by position - :1, :2, and so on. You use the same <input-parameters> and <part> configuration elements, and you must specify the name attribute in <part>, but the value of name is ignored. SQL bind variables are bound to their values by position of the actual arguments - argument in the 1st position - to :1, argument in the 2nd position - to :2, and so on.

The following example demonstrates using the XQS view in a query, with the XQuery declaration and usage corresponding to the preceding <function-name> and <input-parameters> discussion:

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare function xqs:totals($loc as xs:string) as xs:int external;
for $t in xqs:totals("C:\MyPurchaseOrders.xml") return 
<outstanding_balance> fn:sum($t) </outstanding_balance>

Optional or Sometimes Required

The following elements are sometimes necessary or appropriate for an XQS view:

  • <output-element>: Use this to specify the qualified name of the XML element or output type (either a simple type or a complex type) for data that is returned. For an XQS view with WSDLvisibility="true", the <output-element> element is particularly advisable and its location attribute must point to the XML schema file containing the element or type definition. Here is an example:

    <xqsview-source WSDLvisibility="true">
       ...
       <output-element namespace="http://xmlns.oracle.com/ias/xqs/CustomerDemo"
                    location="http://host:port/xqsdemos/Customers.xsd">
       </output-element>
       ...
    </xqsview-source>
    
    

    For an XQS view with WSDLvisibility="false", the <output-element> element is still useful for type-checking. Assume the prefix "xs" has been set to correspond to the XMLSchema namespace:

    <xqsview-source WSDLvisibility="false">
       ...
       <output-element prefix="xs">integer</output-element>
       ...
    </xqsview-source>
    
    
  • <queryName>: Use this to specify the name of the .xq or .sql file where you have saved the XQS view, with or without specifying the .xq or .sql extension (which XQS will append if necessary). The <queryName> element is optional. If you omit it, XQS will assume that the base name of the .xq or .sql file is the same as the XQS function name specified in the <function-name> element.


    Note:

    A XQuery-based XQS view file must have a .xq extension. An SQL-based view file must have a .sql extension. XQS considers a view to be SQL-based only if the <xqsview-source> configuration element contains a <dataSource> subelement. For more information, see "Special Considerations for SQL-Based XQS Views (Always Required)"

    The following example demonstrates an XQS view saved in mytotals.xq:

    <xqsview-source ... >
       ...
       <queryName>mytotals</queryName>
       ...
    </xqsview-source>
    
    

    Given the earlier example for the <function-name> element, if <queryName> were omitted, then XQS would look for a file named totals.xq.

  • <repository>: Use this to specify the location of the XQS view repository (the location of your .xq or.sql file). If you omit this element, XQS assumes the repository is specified using the -repository option of the OC4JPackager.

    For example:

    <xqsview-source ... >
       ...
       <repository>META-INF/xqs/mydir</repository>
       ...
    </xqsview-source>
    
    
  • SQLResultType: an optional attribute of the <xqsview-source> element and is applicable only to SQL-based views. The attribute sets whether database query returns data in the relational (tabular) form or as XML. The default value of SQLResultType is relational. When using the Oracle XML database, you can use the SQL-based XQS view to select XML type values from the database (without subsequent conversion) by setting the SQLResultType attribute to XMLType. XQS relies solely on SQLResultType attribute to determine whether to apply relational-to-XML conversion to the database results. XQS does not analyze the query on its own, because it requires additional round-trip to the database and degrades performance.

    If your database query returns data in the relational form, the SQLResultType attribute must be set to relational either explicitly or by default. In such scenarios, XQS utilizes Oracle XML-SQL Utility (XSU) to convert the relational result to XML.

  • rowTag and rowIdAttr: optional attributes of the <xqsview-source> element and are applicable only to SQL-based views. When specified, they override the default names for elements and attributes respectively, used in the relational-to-XML conversion of the database result. The attributes are applicable only if the SQLResultType attribute is set to relational.

    XSU converts every row in the result set into a XML element. The default element name is ROW. The default element can be customized by setting the rowTag attribute of the <xqsview-source> configuration element. Row elements can be numbered with an attribute of your choice. By default, XSU does not assign numbers to row elements. If you want row numbering, specify the rowIdAttr attribute of the <xqsview-source> configuration element. The value of rowIdAttr attribute is the name of the numbering attribute in the result row element. Rows will be numbered starting from 1, as 1, 2, 3, … The setting rowIdAttr="" is equivalent to the default behavior and suppresses the row numbering attribute.

    The rowTag and rowIdAttr attributes may be used independently from each other. That is, you can specify only one of the attributes and use the default for the other.


    Note:

    XSU transforms each column in the relational result into an element nested in the row element. The element tag is taken from the name of the column. Column element names cannot be customized. However, a column may be assigned an alias name when creating a relational result in the SQL query.

  • fetchSize: an optional attribute of the <xqsview-source> element and is applicable only to SQL-based views. fetchSize recommends the number of rows for JDBC to retrieve from the database in one round trip. This attribute is translated into a call to the setFetchSize method of java.sql.PreparedStatement. The setFetchSize parameter in JDBC (and, therefore, the fetchSize attribute in XQS) is only a hint and may be ignored by the implementation. The default value for fetchSize attribute is 1.

  • XMLFormat: an optional attribute of the <xqsview-source> element and currently has only one enabled value, XSU, which is the default. An additional value will be enabled in a future release to support the Web Rowset result format. The limitation in the current release is caused by dependency on JDK 1.5 functionality.

Considerations for Using <output-element >

When the WSDLvisibility attribute is set to true, XQS generates a Web service operation for the view and includes the definition of this operation in the WSDL document. The contents of <output-element> in <xqsview-source> determine the type of the output message for the WSDL operation, as follows:

  • If <output-element> is omitted, the type of result in the WSDL operation output message will be declared as follows:

    <sequence> <any/> </sequence>
    
    
  • If <output-element> is present, it should provide a namespace for the output element in the form of namespace or prefix attribute. The namespace results in the <import> element in the WSDL. For example:

    <output-element namespace="urn:PurchaseOrders"
                                           location="http://myhost:80/myapp/PurchaseOrders.xsd" />
    

    This code generates the following import element in the WSDL:

    <types>
            <schema...>
               <import namespace="urn:PurchaseOrders" schemaLocation="http://myhost:80/myapp/PurchaseOrders.xsd" />
    ...
    </schema>
    </types>
    
    

    Whenever possible, provide the location attribute because it allows a more complete <import> element in the WSDL.

  • If <output-element> specifies a type attribute, it will be used in conjunction with a namespace or prefix attribute to create a qualified name for the type of the result element. The text value of <output-element> will be used as the name for the result element itself.

    For example:

    <output-element namespace="urn:PurchaseOrders"
                                           location="http://myhost:80/myapp/PurchaseOrders.xsd"
                                           type="POType" >
                                po
    </output-element>
    
    

    This code results in an <import> element, as discussed in the preceding text, plus the following definition of the result type for the WSDL operation:

    <complexType name="POswithRetTypeResultType">
    ...
    <element name="result" nillable="true">
    <complexType >
    <sequence>
              <element name="po" xnlns:_ns1="urn:PurchaseOrders"  type="_ns1:POType" minOccurs="0" maxOccurs="unbounded" />
     </sequence>
    ...
    
    
  • If <output-element> does not specify the type attribute, then the result element in the WSDL operation output message will be declared as a reference to an element in the imported schema. For example, consider the following configuration element:

    <output-element namespace="urn:PurchaseOrders"                                       location="http://myhost:80/myapp/PurchaseOrders.xsd">                            polist                        </output-element>
    

    Such an element generates a result definition in the WSDL like this:

    <complexType name="POListResultType">
    ...
    <element name="result" nillable="true">
    <complexType >
    <sequence>
                 <element ref="_ns1:polist"   minOccurs="0" maxOccurs="unbounded" />
     
    </sequence>
    ...
    
  • If <output-element> specifies the type attribute but is empty (has no text element value), XQS will use a fixed name for the result element, item, but use the type name provided. For example, consider the following configuration:

    <output-element namespace="urn:PurchaseOrders"
                                           location="http://myhost:80/myapp/PurchaseOrders.xsd"
                                           type="POType" />
    
    

    Such a configuration will generate a definition of the result element like this:

    <complexType name="POsResultType">
    ...
    <element name="result" nillable="true">
    <complexType >
    <sequence>
              <element name="item" xnlns:_ns1="urn:PurchaseOrders"  type="_ns1:POType" minOccurs="0" maxOccurs="unbounded" />
     </sequence>
    
    

Important:

The type that defines the result element (through the type attribute in WSDL), or the element that defines the result element by reference (through the ref attribute in WSDL) must refer to a top-level type or element definition in the imported schema. In the preceding examples, POType must be a top-level type definition in the imported schema for the namespace urn:PurchaseOrders; alternatively, polist (used to define an element by reference) must be defined at the top level of the imported schema at this location:

http://myhost:80/myapp/PurchaseOrders.xsd


Special Considerations for SQL-Based XQS Views (Always Required)

<dataSource>: provide the database connection information to XQS. The <dataSource> configuration element is required for XQS views based on SQL queries. The <dataSource> element must contain the JNDI name of a data source, as it is defined in <managed-data-source> or <data-source> element in the OC4J data-sources.xml configuration file.

Performance and Error Handling

You can set up error-handling and specify the use of performance features such as caching or special processing of large data sets. This would involve the <xqsview-source> attributes isCached, largeData, and onError, and subelements <cache-properties> and <error-message>. Configuring these features is not discussed here. Refer to "Using XQS Error Handling Modes and APIs" and "Using XQS Performance Features".

Example

The example that follows puts together previous fragments to configure the XQS function totals, which takes a string variable loc (for a file location) and outputs an integer result. For convenience, here once again is the XQS view, mytotals.xq:

declare variable $loc external;
declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare function xqs:readFile($l as xs:string) external;
for $po in xqs:readFile($loc)//po return $po//total

This example uses default settings for caching, large data, and error handling, which is equivalent to <xqsview-source> attribute settings of isCached="false", largeData="false", and onError="dynamicError". It does not expose the XQS view as a Web service.

<xqsview-source WSDLvisibility="false">
   <function-name namespace="http://xmlns.oracle.com/ias/xqs">
      totals
   </function-name>   
   <input-parameters type-match="none" >
      <part position="1" name="loc">
         <schema-type prefix="xs">string</schema-type>
      </part>
   </input-parameters>
   <repository>META-INF/xqs/mydir</repository>
   <queryName>mytotals</queryName>
   <output-element prefix="xs">int</output-element>
</xqsview-source>

Configuring an XQS Function that Accesses a WSDL Source

This section discusses how to configure an XQS function that accesses a WSDL-based source, concluding with a partial sample WSDL document and corresponding configuration. Elements mentioned here are subelements of the <wsdl-source> element. For additional information, see the reference section "<wsdl-source>", which includes links to information about all the subelements.

Depending on the type of WSDL source you are using, also see "Preparing to Use a WSDL Source with SOAP Binding", or "Preparing to Use a Custom Class or EJB (WSDL Source with Java or EJB Binding)".

Always Required

At a minimum, you must configure the following elements for a WSDL source:

  • <function-name>: Through this element, specify the qualified name you want to use for the XQS function that XQS implements to access the WSDL source. The element value is the local name, and there are attributes for the namespace (either namespace or prefix, as discussed in "<function-name>"). Your XQuery prolog must use the same name when declaring the XQS function as an XQuery external function.

    Here is a sample configuration:

    <wsdl-source ... >
       <function-name namespace="http://xmlns.oracle.com/ias/xqs">
          getmySearchCachedPage
       </function-name>
       ...
    </wsdl-source>
    
    
  • <input-parameters>: For every WSDL source, the function implemented by XQS must take an input parameter for each input part specified in the WSDL. Use the <input-parameters> element to configure input parameters, with a <part> subelement for each parameter. Note that this element is always required for a WSDL source; use an empty element if there is no input:

    <wsdl-source ... >
       ...
       <input-parameters/>
       ...
    </wsdl-source>
    
    

    Following is an example with two input parameters, external string variables named key and url. Type information, through a <schema-type> element, is optional for input parameters for a WSDL source; however, it is useful so that XQS can perform type-checking during invocation of the Web service. In the example, assume the "xs" prefix has been set to correspond to the XMLSchema namespace. (See reference documentation later in this chapter for information about the <input-parameters>, <part>, and <schema-type> elements.)

    <wsdl-source ... >
       ...
       <input-parameters>
          <part position="1" name="key" >
             <schema-type prefix="xs">string</schema-type>
          </part>
          <part position="2" name="url" >
             <schema-type prefix="xs">string</schema-type>
          </part>
       </input-parameters>
       ...
    </wsdl-source>
    
    
  • <wsdlURL>: Specify a URL that instructs XQS where to find the WSDL document. For example:

    <wsdl-source ... >
       ...
       <wsdlURL>http://api.mySearch.com/mySearch.wsdl</wsdlURL>
       ...
    </wsdl-source>
    
    
  • <operation>: Specify the Web service operation to execute, corresponding to an operation name in the WSDL. For example:

    <wsdl-source ... >
       ...
       <operation>doGetCachedPage</operation>
       ...
    </wsdl-source>
    
    
  • <port>: Specify the applicable Web service port, corresponding to a port name in the WSDL. For example:

    <wsdl-source ... >
       ...
       <port namespace="urn:mySearch">mySearchPort</port> 
       ...
    </wsdl-source>
    
    

Here is a sample function declaration corresponding to the <function-name> and <input-parameters> used in the preceding examples:

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare function xqs:getmySearchCachedPage ($key as xs:string, $url as xs:string)
        as xs:base64Binary external;

Optional or Sometimes Required

The following elements are sometimes necessary or appropriate for a WSDL source.

  • <service>: Use this to specify the applicable service, corresponding to a service name in the WSDL. This is not required, however, if the WSDL defines only one service. Here is a sample service configuration:

    <wsdl-source ... >
       ...
       <service namespace="urn:mySearch">mySearchService</service>
       ...
    </wsdl-source>
    
    
  • <portType>: Use this to specify the applicable port type, corresponding to a port type name in the WSDL. This is not required, however, if the port in the WSDL supports only one binding (and, therefore, only one port type). Here is a sample port type configuration:

    <wsdl-source ... >
       ...
       <portType namespace="urn:mySearch">mySearchPort</portType>
       ...
    </wsdl-source>
    
    
  • <output-element>: You can optionally use this to specify the qualified name of the XML output element or type (either a simple type or a complex type) for data that is returned. This is not required, but XQS can use the information for type-checking. Here is an example:

    <wsdl-source ... >
       ...
       <output-element namespace="http://xmlns.oracle.com/ias/xqs/CustomerDemo"
                    location="http://host:port/xqsdemos/Customers.xsd"> type="Customers>
       </output-element>
       ...
    </wsdl-source>
    
    
  • <typeMap>: For a WSDL source with Java or EJB binding, you can use this element to map XML types to Java types, using the <mapping> subelement and its <xmlType> subelement as shown. (See the reference documentation later in this chapter for more information about the <typeMap>, <mapping>, and <xmlType> elements.)

    <wsdl-source ... >
       ...
       <typeMap>
          <mapping typeClass="org.w3c.dom.Node">
             <xmlType prefix="myeis">Customer</xmlType>
          </mapping>
          ...
       </typeMap>
       ...
    </wsdl-source>
    
    

    (A <typeMap> element would be ignored for a WSDL source with a SOAP binding.)

Performance and Error Handling

You can set up error-handling and specify the use of caching. This would involve the <wsdl-source> attributes isCached and onError, and subelements <cache-properties> and <error-message>. Configuring these features is not discussed here. Refer to "Using XQS Error Handling Modes and APIs" and "Configuring XQS Caching".

Example

This example puts together some of the previous fragments to configure an XQS function for a Web service operation defined in mySearch.wsdl, a portion of which follows.

The example uses default settings for caching and error handling, which is equivalent to <wsdl-source> attribute settings of isCached="false" and onError="dynamicError".

<wsdl-source>
   <function-name namespace="http://xmlns.oracle.com/ias/xqs">
      getmySearchCachedPage
   </function-name>
   <wsdlURL>http://api.mySearch.com/mySearch.wsdl</wsdlURL>
   <operation>doGetCachedPage</operation>
   <service namespace="urn:mySearch">mySearchService</service>
   <port namespace="urn:mySearch">mySearchPort</port> 
   <input-parameters>
      <part position="1" name="key" >
         <schema-type prefix="xs">string</schema-type>
      </part>
      <part position="2" name="url" >
         <schema-type prefix="xs">string</schema-type>
      </part>
   </input-parameters>
</wsdl-source>

mySearch.wsdl

Here are relevant fragments of mySearch.wsdl, relating to the preceding configuration. Highlighted WSDL portions correspond to configuration elements.

<?xml version="1.0" ?> 
 
<definitions name="mySearch" targetNamespace="urn:mySearch"
   xmlns:typens="urn:mySearch"
   xmlns:xs="http://www.w3.org/2001/XMLSchema"
   xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
   xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/"
   xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
   xmlns="http://schemas.xmlsoap.org/wsdl/">
   ...
   <message name="doGetCachedPage">
      <part name="key" type="xs:string" /> 
      <part name="url" type="xs:string" /> 
   </message>
   <message name="doGetCachedPageResponse">
      <part name="return" type="xs:base64Binary" />
   </message>
   ...
   <portType name="mySearchPort">
      <operation name="doGetCachedPage">
         <input message="typens:doGetCachedPage" /> 
         <output message="typens:doGetCachedPageResponse" /> 
      </operation>
      ...
   </portType>
   ...
   <binding name="mySearchBinding" type="typens:mySearchPort">
      <soap:binding style="rpc" 
                    transport="http://schemas.xmlsoap.org/soap/http" /> 
      <operation name="doGetCachedPage">
         <soap:operation soapAction="urn:mySearchAction" /> 
         <input>
            <soap:body use="encoded" namespace="urn:mySearch"
               encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" /> 
         </input>
         <output>
            <soap:body use="encoded" namespace="urn:mySearch"
               encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" /> 
         </output>
      </operation>
      ...
   </binding>
   ...
   <service name="mySearchService">
      <port name="mySearchPort" binding="typens:mySearchBinding">
         <soap:address location="http://api.mySearch.com/search/beta2" /> 
      </port>
   </service>
</definitions>

How to Design Your Queries

This chapter assumes developers are already familiar with the XQuery language and the basics of how to design an effective and efficient query, but this section will summarize key points to consider, including special considerations for working with XQS, and includes query examples. The following topics are covered:


Notes:

  • Oracle fully supports XQuery 1.0, so you can use any syntax that XQuery supports.

  • You can use any third-party tool to help you develop your queries, including the Oracle JDeveloper Query Builder, but currently no tools, including JDeveloper, provide any special support for XQS.


Query Considerations

As a first step, of course, you must consider your data source, including how to access it and the types of data it contains. "How to Prepare to Use Your Data Sources" already discussed any preliminary steps you must take for certain kinds of data sources.

Then you must consider aspects of the query itself, including the following:

  • Will your query require input parameters? If so, do you want type-checking? (See "Type-Checking for Input Parameters".)

  • What are the data types of any input parameters and the query return value?

  • Will you want to transform the data, outputting it into another XML structure?

  • Will you want to use an ad-hoc query, or save the query as an XQS view (.xq file)?

  • Are there tuning and performance considerations, and will you want to use XQS performance features? XQS can cache source data, and also has a special mode for processing large volumes of data. (See "Using XQS Performance Features" for details.)

As discussed previously, XQS implements an external XQuery function to access the data source. Your XQuery prolog must include a declaration for the function that XQS creates, using a function name you choose, and must reference the appropriate namespace. The function name you declare must match the name you specify in the <function-name> element when you configure the data source (as described under "How to Configure Your XQS Functions").

Query Examples

Here is a simple query that retrieves data from an XML document, the location of which is passed in to the XQS function at runtime:

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs"; 
declare function xqs:get_poSQ($bind as xs:string) external;
for $po in xqs:get_poSQ("http://host:port/xqsdemos/Repository/pos-2KB.xml") 
return  $po

XQS implements the function according to your XQS configuration. The function name (get_poSQ in this example) is of your choosing. The function takes as input a string with the name and location of the document source, pos-2KB.xml, and returns purchase order data from the file.

Now here is an example that passes in parameter values through the XQuery code. The XQS function is example, implemented by XQS according to your configuration.

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare function xqs:example($i as xs:int, $d as xs:duration, 
                             $h as xs:hexBinary, $bin as xs:base64Binary, 
                             $t as xs:boolean) external;

for $result in xqs:example(xs:int(1),
                           xs:duration("P1Y2MT2H"),
                           xs:hexBinary("0FB7"),
                           xs:base64Binary("vYrfOJ39673//-BDiIIGHSPM=+"),  
                           xs:boolean("true"))
return $result;

Following is a more complicated example for a query that, given the name of a customer, searches a payment record for orders by that customer. It returns information about the customer and the customer's orders. There are two data sources involved: 1) customer information is in a data source accessed through a custom WSIF extension "myeis"; and 2) payment information is in an Excel spreadsheet (non-XML document source). To access the data source for customer information, the XQS function customerInfo is used, taking a string with the customer name as input. That function accesses the customer information data source and yields information for the specified customer, including a customer key. Then the payment information Excel file is accessed, using the XQS function paymentStatusInfo, and order information is returned for the customer whose key matches the key from the customer information data source. Note the XQuery code includes an XML transformation of the results.

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
(: returns payment info for all customers:)
declare function xqs:paymentStatusInfo() external;
 
(: returns customer info given customer name :)
declare function xqs:customerInfo ($name as xs:string) external;
 
(: customer name passed in to query :)
declare variable $custName external;
 
let $custInfo := xqs:customerInfo($custName)
for $custOrderInfo in xqs:paymentStatusInfo()/excel/Row[CustomerKey eq $custInfo/key] 
return 
   <result>
      <MYEIS_RESULT>
         <Row>
            <Name> { $custInfo/name } </Name>
            <Company> { $custInfo/company} </Company>
            <Address> { $custInfo/address} </Address>
            <City> { $custInfo/city} </City>
            <State> { $custInfo/state} </State>
            <Zip> { $custInfo/zip} </Zip>
         </Row>
      </MYEIS_RESULT>
      <EXCEL_RESULT>
         <Row>
            <OrderID>{$custOrderInfo/OrderId}</OrderID>
            <Amount>{$custOrderInfo/Amount}</Amount>
            <PaymentStatus>{$custOrderInfo/PaymentStatus}</PaymentStatus> 
         </Row>
      </EXCEL_RESULT>
   </result>

Type-Checking for Input Parameters

For a WSDL source or XQS view, if you want XQuery to perform additional type-checking steps before sending input arguments to the underlying data source, then take the following steps:

  1. For each input parameter, which is specified in your configuration for the applicable XQS function through a <part> subelement under the <input-parameters> element, specify the parameter type. For XQS view sources, this would be through one of the following, as appropriate:

    • A <schema-type> subelement of <part>

    • For an input sequence, an <xquery-sequence> subelement of <part>, with the <itemType> subelement of <xquery-sequence>

    For WSDL sources, which do not support a sequence as input, only <schema-type> is relevant.

    (See the reference documentation later in this chapter for details about all these elements.)

  2. Include the parameter types with the function declaration in the XQuery prolog.

  3. If input parameters are of user-defined types, import the schema or files containing the type definitions.

Here is an example. First, the XQS configuration:

<wsdl-source isCached="false">
   <function-name namespace="http://xmlns.oracle.com/ias/xqs">
      SplitRatio
   </function-name>
   ...
   <input-parameters>
      <part position="1" name="parameters">
         <schema-type namespace="http://www.xignite.com/services/">
            GetSplitRatio
         </schema-type>
      </part>
   </input-parameters>
</wsdl-source>

Then, the corresponding XQuery expression:

import schema namespace xignite="http://www.xignite.com/services/" 
       at "http://www.xignite.com/xSecurity.asmx?wsdl"
declare namespace xqs="http://xmlns.oracle.com/ias/xqs";
declare function xqs:SplitRatio($params as xignite:GetSplitRatio)
        as xignite:GetSplitRatioResponse external;

let $in := <xignite:GetSplitRatio> .....</xignite:GetSplitRatio>

let $y := xqs:SplitRatio($in) return <split>$y//xignite:Ratio</split>

At execution time, XQuery will ensure that the argument passed into xqs:SplitRatio is of the type xignite:GetSplitRatio from the imported schema.

How to Develop Your Application Code: Using the XQS Client Interfaces

This section discusses the steps involved in using the client APIs that XQS provides (first discussed in "Introduction to XQS Client Interfaces"), and offers some examples. The focus is on the Java client API, the EJB client API, and the JSP tag library. For Web service clients, the particulars of what XQS does to expose an XQS view as a Web service operation are left to the packaging discussion—see "OC4JPackager Additional Output to Expose XQS Views As Web Service Operations". Otherwise, XQS generates a regular WSDL with SOAP 1.1 binding, and we assume readers are knowledgeable about creating Web service clients.


Note:

XQS does not generate Java code for a Web service client. It is a responsibility of the user to invoke the Web service dynamically or generate the client invocation code based on the WSDL.

The following topics are covered here:


Notes:

  • We assume that before you use any of the XQS client interfaces, you have prepared and configured your data source as described in "How to Prepare to Use Your Data Sources" and "How to Configure Your XQS Functions". We also assume you have completed any additional configuration, such as the ejb-jar.xml file if you use an EJB, or web.xml file if you use a Web module.

  • Your choice of which client API to use is independent of the type of data source you use. These are entirely separate considerations.


Supported Types for Query Parameters

The XQS oracle.xqs.client.QueryParameterI interface is for use with the XQS Java client API and EJB client API for arrays of bind parameters for queries. It is also used behind the scenes with the XQS JSP tag library. (See "XQS QueryParameterI Reference" for additional information.) Table 8-2 shows the correspondence between XML types that XQS supports, and Java types that you use to pass input values through instances of the QueryParameterI interface.

Table 8-2 XQS Type Support for Bind Parameters

Supported XML Type Corresponding Java Type for QueryParameterI interface

boolean

boolean

string

java.lang.String

int

int

integer

int, long, java.math.BigInteger

long

long

float

float

double

double

decimal

java.math.BigDecimal

base64Binary

java.lang.String

hexBinary

java.lang.String

anyURI

java.net.URI

dateTime

java.util.GregorianCalendar

(With the assumption that the time zone for the calendar value has been initialized appropriately)

java.lang.String(Lexical representation of the dateTime, discussed at http://www.w3.org/TR/xmlschema-2/#dateTime)

duration

java.lang.String(Lexical representation of the duration, discussed at http://www.w3.org/TR/xmlschema-2/#duration)

dayTimeDuration

double

(representation of dayTime duration in seconds)

yearMonthDuration

int

(representation of yearMonth duration in months)

anyType, user-defined XML types

org.w3c.dom.Node


General Coding Steps in Using XQS Client APIs

There are several basic coding steps in using the XQS client APIs:

  1. Create your query. To use an ad-hoc query, this may consist of hard-coding a query or writing code to accept a query from user input. To use an XQS view, this consists of saving the query in an .xq file. Also see "How to Design Your Queries".

  2. Obtain an instance of the XQSFacadeI interface from the XQSFactory factory with the help of the static method getXQSFacade() , or by including the XQS JSP tag library in a JSP page.

  3. Specify any input parameters. For the Java client API or EJB API, create an array of type oracle.xqs.client.QueryParameterI and populate it by obtaining instances of the QueryParameterI interface from the XQSFactory factory with the help of the static method getQueryParameter(). (See "XQS QueryParameterI Reference".) For the JSP tag library, use the param subtag of execute or executeCursor. (See "XQS param Tag".) Also see the preceding section, "Supported Types for Query Parameters".

  4. Execute the query.

  5. Read and process the results. For a stateless client, XQS either returns the results all at once in a java.util.Vector instance or, if you are using the JSP tags, returns a java.util.ArrayList instance and an XML document. For a stateful client, you retrieve the results item by item, either using the Oracle XQuery type oracle.xml.xqxp.datamodel.XMLItem, or, if you employ the JSP tags, using java.lang.Object instances and nodes of an XML document. For the XQS EJB API and JSP tag library, you have the option of using either a stateless or stateful access pattern.

    The XQSFacadeI interface uses a stateful access pattern. See "Using the Java Interface Client API" for information about using the XQSFacadeI interface.

  6. Optionally retrieve and process errors. If you configure XQS to continue even if errors are encountered during execution of the XQS function for the query, you can retrieve information about the errors. See "Using XQS Error Handling Modes and APIs".

  7. When using a stateful client, close the client object to free all resources associated with the query.


Note:

This discussion does not include security or performance considerations. See "Security for XQS Applications" and "Using XQS Performance Features" for information on those topics.

Stateful Versus Stateless Clients

The XQS client APIs return query results as an XML sequence—one or more XML items, where each item may be an XML document, XML node, or primitive value. It is important to realize that the query execution defines the result, but does not necessarily materialize all result items into process memory immediately. An XML sequence, like a result set from a relational query, implicitly maintains a "cursor" that is initially positioned in front of the first item in the sequence and may be advanced by a "next" operation. If an XML sequence is accessed through the implicit cursor, through repeated calls to a "next" operation, then any of the "next" calls may trigger the actual evaluation of the XQuery expression in order to produce the next item requested. The exact moment when XQuery evaluates the expression and whether XQuery evaluates it incrementally or all at once depend on the specific XQuery expression and the level of optimization of the XQuery implementation. As an alternative to using this sort of cursor access, though, the XQS client APIs also offer reading all query results immediately into process memory in a single step.

Each of the single-step and cursor modes of execution has advantages and disadvantages. For most situations, single-step execution is preferable, because associated resources (such as connections to the underlying data sources, and internal XQuery resources dedicated to the expression) are freed immediately after the evaluation is completed. You also do not have the potential performance impact of repeated trips to the data source. However, single-step execution is not feasible when the total size of items in the result sequence may be too large, such that materializing the whole sequence at one time would run out of process memory. In this case, cursor mode is the only option, as long as there is nothing (such as aggregate expressions, for example) preventing the query from providing the results item-by-item.

To allow the choice between the single-step and cursor modes, XQS provides two types of client APIs: stateless for single-step mode, or stateful for cursor mode. (In this discussion, "state" refers to the internal state of the XQuery engine.) These work as follows:

  • When an XQuery expression is executed through a stateless API, the entire result sequence is materialized at once, and all internal state and resources are freed immediately afterward. The only requirement for stateless execution is that the entire result sequence must fit into process memory.

  • By contrast, executing an XQuery expression through a stateful API results in placement of the "current" position in front of the first item in the result sequence. To obtain each item, starting with the first item, the client must invoke a "next" operation. The current position and all the internal resources necessary to evaluate the next item constitute the state of the query. This state is freed only after the last item in the sequence is returned, or if the query is explicitly closed. It is important to note, however, that to take advantage of the reduced memory requirements of stateful execution, the client code must release each result item once it has been processed.

The XQS EJB client API and JSP client API each has features for stateless execution and features for stateful execution. The XQS Java interface (XQSFacadeI) client API provides stateful access. Users can simulate stateless access by immediately getting all result items and freeing the client object.

Using the Java Interface Client API

Refer to the "General Coding Steps in Using XQS Client APIs". Do as follows to apply these steps using the XQS Java client API (after creating your query):

  1. Obtain an instance of the XQSFacadeI interface from the XQSFactory factory with the help of the static method getXQSFacade(). Method calls in the following steps are called from this instance.

  2. Create a QueryParameterI array for any input parameters and populate it by obtaining instances of the QueryParameterI interface from the XQSFactory factory with the help of the static method getQueryParameter().

  3. Use the execute() method to execute an ad-hoc query, or the executeView() method to execute an XQS view, passing in the query and QueryParameterI array (or null if there are no input parameters). For executeView(), also pass in the namespace of the XQS function for the view.

  4. If you configured any data sources used in the query with the emptySequence or errorMessage error mode, optionally use the getErrors() method to retrieve any errors encountered during execution of the query. This returns an iterator over a collection of XQSErrorI objects. See "Using XQS Error Handling Modes and APIs" for information about error configuration and processing.

  5. Repeatedly use the getNextItem() method to get the results back item by item. Each item is returned in an XMLItem instance. Process these items as desired.

  6. Use the close() method to free all resources associated with the query.

These steps are shown in examples that follow. Also see "XQSFacadeI Reference" for reference information.

Example 1: XQSFacadeI API

This example shows general use of the XQSFacadeI API. The query returns bind parameters in a sequence, showing how to bind and how to retrieve data. No configuration is necessary, because the query does not use any functions.

For processing query results, the code uses the XMLItem class (in the oracle.xml.xqxp.datamodel package).

import oracle.xml.xqxp.datamodel.XMLItem;
import oracle.xml.parser.v2.XMLDocument;
import oracle.xml.parser.v2.XMLElement;
import oracle.xqs.client.XQSFacadeI;
import oracle.xqs.client.QueryParameterI;
import oracle.xqs.client.XQSErrorI;
import java.util.Vector;

public class XQSFacadeITest {
public static void main(String[] args) throws Exception {
 try{
          //get XQSFacadeI
          XQSFacadeI facade = XQSFactory.getXQSFacade();
          String xquery = "declare variable $bind1 external;\n"+
             "declare variable $bind2 external;\n"+
             "declare variable $bind3 external;\n"+
             "declare variable $bind4 external;\n"+
             "declare variable $bind5 external;\n"+
             "declare variable $bind6 external;\n"+
             "declare variable $bind7 external;\n"+
             "declare variable $bind8 external;\n"+
             "declare variable $bind9 external;\n"+
             "declare variable $bind10 external;\n"+
             "declare variable $bind11 external;\n"+
             "declare variable $bind12 external;\n"+
             "declare variable $bind13 external;\n"+
             "declare variable $bind14 external;\n"+
             "declare variable $bind15 external;\n"+
             "declare variable $bind16 external;\n"+
             "("+"$bind1,$bind2,$bind3,$bind4,$bind5,$bind6,$bind7,\n"+
             "$bind8,$bind9,$bind10,$bind11,$bind12,$bind13,$bind14,$bind15,
                $bind16)";

          QueryParameterI params[] = new QueryParameterI[16];
          params[0]=XQSFactory.getQueryParameter ("bind1");
          params[0].setString("test");
          params[1]=XQSFactory.getQueryParameter ("bind2");
          params[1].setInteger(new BigInteger("100"));
          params[2]=XQSFactory.getQueryParameter ("bind3");
          params[2].setBoolean(true);
          params[3]=XQSFactory.getQueryParameter ("bind4");
          params[3].setFloat(-1);
          params[4]=XQSFactory.getQueryParameter ("bind5");
          params[4].setDuration("P1Y2M3DT10H30M");
          params[5]=XQSFactory.getQueryParameter ("bind6");
          params[5].setDouble(-11.0);

          TimeZone LAtz = new SimpleTimeZone(-28800000,
          "America/Los_Angeles",
                Calendar.APRIL, 1, -Calendar.SUNDAY,
                7200000,
                Calendar.OCTOBER, -1, Calendar.SUNDAY,
                7200000,
                3600000);
          GregorianCalendar cal = new GregorianCalendar(LAtz);

       params[6]=XQSFactory.getQueryParameter ("bind7");
       params[6].setDateTime(cal,true);

       URI uri = new URI("http://www.test.com");

       params[7]=XQSFactory.getQueryParameter ("bind8");
       params[7].setAnyURI(uri);
       params[8]=XQSFactory.getQueryParameter ("bind9");
       params[8].setInt(-7);
       params[9]=XQSFactory.getQueryParameter ("bind10");
       params[9].setLong(50l);
       params[10]=XQSFactory.getQueryParameter ("bind11");
       params[10].setDecimal(new BigDecimal(999999));
       params[11]=XQSFactory.getQueryParameter ("bind12");
       XMLDocument document = new XMLDocument();

          Element elem = document.createElementNS("http://client.xqs.oracle/",
             "tns:result");
          document.appendChild(elem);

       params[11].setNode(elem);
       params[12]=XQSFactory.getQueryParameter ("bind13");
       params[12].setBase64Binary("vYrfOJ39673//-BDiIIGHSPM=+");
       params[13]=XQSFactory.getQueryParameter ("bind14");
       params[13].setHexBinary("0FB7");
       params[14]=XQSFactory.getQueryParameter ("bind15");
       params[14].setDayTimeDuration(60.5);
       params[15]=XQSFactory.getQueryParameter ("bind16");
       params[15].setYearMonthDuration(13);

       facade.execute(xquery, params);
       // lookup functions
       XMLItem item = facade.getNextItem();
 
       while(item != null) {
         if (item.instanceOfType(XMLItem.XMLITEM_STRING)) {
            System.out.println("string item value: expected: \Ótest\Ó, 
            actual:", item.getString());
         }
         else if (item.instanceOfType(XMLItem.XMLITEM_INT)) {
            System.out.println("int item value: expected: \Ó-7\Ó, actual: ",
            item.getInt());
         }
         else if (item.instanceOfType(XMLItem.XMLITEM_LONG)) {
            System.out.println("long item value: expected: \Ó501\Ó, actual: ",
            item.getInt());
         }
         else if(item.instanceOfType(XMLItem.XMLITEM_INTEGER)) {
            if(item.intFormat())
               System.out.println("integer item value: expected: \Ó100\Ó,
               actual:", item.getInt());
            else
              System.out.println("integer item value: expected: \Ó100\Ó,
              actual: ", item.getDecimal().intValue());
            }
            else if(item.instanceOfType(XMLItem.XMLITEM_BOOLEAN)) {
               System.out.println("boolean item value: expected: \Ótrue\Ó, 
               actual: ", item.getBoolean());
            }
            else if(item.instanceOfType(XMLItem.XMLITEM_FLOAT)) {
               System.out.println("float item value: expected: \Ó-1\Ó,
               actual: ",(float)item.getDouble());
            }
            else if (item.instanceOfType(XMLItem.XMLITEM_XDT_DAYTIMEDURATION)) {
               System.out.println("dayTimeDuration item value: expected: \Ó60.5 
               seconds\Ó, actual: ", item.getDayTimeDuration());
            }
            else if (item.instanceOfType(XMLItem.XMLITEM_XDT_YEARMONTHDURATION)) {
               System.out.println("yearMonthDuration item value: expected: \Ó13
               months\Ó, actual: ",  item.getYearMonthDuration());
            }
            else if (item.instanceOfType(XMLItem.XMLITEM_DURATION)) {
               System.out.println("duration item value: expected: \Ó
               P1Y2M3DT10H30M \Ó, actual: ", item.getLexicalValue());
            }
            else if(item.instanceOfType(XMLItem.XMLITEM_DOUBLE)) {
               System.out.println("double item value: expected: \Ó –11.0\Ó,
               actual: ", item.getDouble());
            }
            else if(item.instanceOfType(XMLItem.XMLITEM_DATETIME)) {
               System.out.println("dateTime item value: expected Timezone:
               \ÓPacific (Latz) \Ó, actual: ", item.getCalendar().getTimeZone());
            }
            else if (item.instanceOfType(XMLItem.XMLITEM_ANYURI)) {
               System.out.println("anyURI item value: expected:
               \"http://www.test.com\", actual: ", item.getString());
            }
            else if (item.instanceOfType(XMLItem.XMLITEM_DECIMAL)) {
               System.out.println("decimal item value: expected: \Ó999999 \Ó,
               actual: ", item.getDecimal().intValue());
         }
         else if(item.instanceOfType(XMLItem.XMLITEM_NODE)) 
         {
            XMLElement node = (XMLElement)item.getNode();

            //when obtained from document function, it returns XMLDocument
            if(node instanceof XMLDocument)
               node = (XMLElement)node.getFirstChild();
            System.out.println("node item value: expected namespace: \Ó
               http://client.xqs.oracle \Ó, actual: ",node.getNamespaceURI());
            System.out.println("node item value: expected local name: \Óresult\Ó,
               actual: ",node.getLocalName());
         }
         else if (item.instanceOfType(XMLItem.XMLITEM_HEXBINARY)) {
            System.out.println("hexBinary item value: expected: \Ó0FB7\Ó, 
               actual: ", item.getString());
         }
         else if (item.instanceOfType(XMLItem.XMLITEM_BASE64BINARY)) {
            System.out.println("base64Binary item value: expected: \Ó
               vYrfOJ39673//-BDiIIGHSPM=+ \Ó, actual: ", item.getString());
         }
         else 
            {
            System.out.println("item type not supported:"+item.getLexicalValue());
            }
            item = facade.getNextItem();
         }
      }catch(Exception ex){
         ex.printStackTrace();
         fail(ex.getMessage());
         assertTrue("xquery execution failed", false);
    } 
    facade.close();
  }
}

Example 2: XQSFacadeI API with an Ad-Hoc Query

This section has a Java class to show the steps of using the XQSFacadeI API in your client code, along with related XQS configuration. The example has an ad-hoc query that uses an XQS view source, which in turn uses a document source.

Query This example uses the following ad-hoc query:

declare namespace xqs="http://xmlns.oracle.com/ias/xqs";
declare function xqs:get_poSQ($bind as xs:string) external;
for $po in xqs:get_poSQ("http://localhost:8888/myrepository/pos-2KB.xml")
    return $po

Configuration The query in turn uses the XQS function get_poSQ, which corresponds to an XQS view source that is configured as shown in the following example. By default, if the .xq file name and location are not specified in the configuration (through the <queryName> and <repository> elements), the file name is assumed to match the function name, and the location is assumed to be as specified through the -repository option when you run OC4JPackager.

<xqsview-source>
   <function-name prefix="xqs">get_poSQ</function-name>
   <input-parameters>
      <part position="1" name="bind" >
         <schema-type prefix="xs">string</schema-type>
      </part>
   </input-parameters>
</xqsview-source>

The XQS view get_poSQ, defined in the file get_poSQ.xq, uses a document source and is defined as follows:

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs";
declare variable $bind external;
declare function xqs:genericFile($bind as xs:string) external;
for $po in xqs:genericFile($bind)//po
   return $po

And the document source genericFile is configured as follows:

<document-source>
   <function-name namespace="http://xmlns.oracle.com/ias/xqs">
      genericFile
   </function-name>
</document-source>

The genericFile function takes the document URL as input, so there is no <documentURL> element.

Java Code The code follows—a complete class that does the following:

  • Obtain an instance of the XQSFacadeI interface from the XQSFactory factory with the help of the static method getXQSFacade(). .

  • The ad-hoc query, which uses the XQS view get_poSQ, is defined. The query is stored in the string xqueryStr after being pieced together in a string buffer xqueryBuf. The URL for the backend document source is taken by the get_poSQ function as input.

  • The query is executed. There are no input parameters for the query, so null is passed in to the execute() method where the QueryParameterI array would go. (The next example, "Example 3: XQSFacadeI API with an XQS View", shows an input parameter.)

  • No error processing is shown here, but if you have appropriate configuration of the source (error mode errorMessage or emptySequence), you could retrieve and process error objects. (The next example also shows error processing. Or see "Using XQS Error Handling Modes and APIs" for additional information.)

  • A while loop goes through the result sequence item by item. Each item is a node, so is placed into an XML document, doc. From there, results can be displayed or further processed as desired (from that point, the processing is not XQS-specific).

  • A close() call closes the cursor and frees associated resources.

import oracle.xml.xqxp.datamodel.XMLItem;
import oracle.xml.parser.v2.XMLDocument;
import oracle.xml.parser.v2.XMLElement;
import oracle.xml.parser.v2.XMLNode;
import oracle.xqs.client.XQSFacadeI;
 
public class XQSFacadeITest {
 
    public static void main(String[] args) throws Exception{
        XQSFacadeI bean = XQSFactory.getXQSFacade();
        StringBuffer xqueryBuf = new StringBuffer();
        xqueryBuf.append
             ("declare namespace xqs=\"http://xmlns.oracle.com/ias/xqs\";\n");
        xqueryBuf.append
             ("declare function xqs:get_poSQ($bind as xs:string) external;\n");
        xqueryBuf.append("for $po in xqs:get_poSQ
                     (\"http://localhost:8888/myrepository/pos-2KB.xml\") \n");
        xqueryBuf.append("return $po\n");
 
        String xqueryStr = xqueryBuf.toString();
 
        //no parameters to be bound, so pass null
        bean.execute(xqueryStr, null);
 
        XMLItem item = bean.getNextItem();
 
        XMLDocument doc = new XMLDocument();
        XMLElement rootElem = (XMLElement)doc.createElement("QueryResult");
        doc.appendChild(rootElem);
 
        while(item != null) {
            /* the test is actually superfluous - all items are expected to nodes
               for Purchase Order, here we show a standard treatment of items that
               are XML nodes, including entire documents
               (where node type is DOCUMENT_NODE)
            */
            if(item.getItemType().isNode()) {
                   rootElem.appendChild(doc.importNode(
                      item.getNode().getNodeType()==
                                         XMLNode.DOCUMENT_NODE?(XMLNode)
                      ((XMLDocument)item.getNode()).getDocumentElement():
                      (XMLNode)item.getNode(), true));
            }
            item = bean.getNextItem();
       }
       bean.close();
    }
}

Example 3: XQSFacadeI API with an XQS View

This section has an example using the XQSFacadeI API to execute an XQS view directly through an executeView() call.

Configuration Here is the configuration for an XQS view named BasicFileWS:

<xqsview-source WSDLvisibility="true" isCached="false" onError="errorMessage">
   <function-name  prefix="xqs">BasicFileWS</function-name>
   <input-parameters type-match="none" >
      <part position="1" name="custName">
         <schema-type prefix="xs">string</schema-type>
      </part>
   </input-parameters>
   <output-element namespace="http://xmlns.oracle.com/ias/xqs/CustomerDemo" 
                location="http://host:port/xqsdemos/MyTypes.xsd" type="CustomerOrdersType">
   </output-element>
</xqsview-source>

There is no <queryName> element, so the .xq file name is assumed to be BasicFileWS.xq (matching the specified function name). The view takes a string parameter, custName, as input.

Here is the definition of the view BasicFileWS.xq (a query discussed earlier, in "Query Examples"), including the variable to take the customer name as input. This view uses two XQS functions, for data sources whose configurations are shown immediately following.

declare namespace xqs = "http://xmlns.oracle.com/ias/xqs" ;
(: returns payment info for all customers:)
declare function xqs:paymentStatusInfo () external;
 
(: returns customer info given customer name :)
declare function xqs:customerInfo ($name as xs:string) external;
 
(: customer name passed in to query :)
declare variable $custName external;
 
let $custInfo := xqs:customerInfo($custName)
for $custOrderInfo in xqs:paymentStatusInfo()/excel/Row[CustomerKey eq $custInfo/key] 
return 
   <result>
      <MYEIS_RESULT>
         <Row>
            <Name> { $custInfo/name } </Name>
            <Company> { $custInfo/company} </Company>
            <Address> { $custInfo/address} </Address>
            <City> { $custInfo/city} </City>
            <State> { $custInfo/state} </State>
            <Zip> { $custInfo/zip} </Zip>
         </Row>
      </MYEIS_RESULT>
      <EXCEL_RESULT>
         <Row>
            <OrderID>{$custOrderInfo/OrderId}</OrderID>
            <Amount>{$custOrderInfo/Amount}</Amount>
            <PaymentStatus>{$custOrderInfo/PaymentStatus}</PaymentStatus> 
         </Row>
      </EXCEL_RESULT>
   </result>

Here is the configuration for the document source associated with the function paymentStatusInfo. This is a non-XML document, so D3L is used for conversion. (See "Preparing to Use a Non-XML Document Source".)

<document-source isCached="false">
   <function-name prefix="xqs">paymentStatusInfo</function-name>
   <documentURL>http://host:port/xqsdemos/paymentInfo.csv</documentURL>
   <XMLTranslate method="D3L"> 
      <schema-file>
         http://host:port/xqsdemos/paymentInfoD3L.xml
      </schema-file>
   </XMLTranslate>
</document-source>

And here is the configuration for the WSDL source associated with the function customerInfo. This includes some information for Java-to-XML type mapping.

<wsdl-source isCached="false">
   <function-name  namespace="http://xmlns.oracle.com/ias/xqs">
      customerInfo
   </function-name>
   <wsdlURL>http://host:port/xqsdemos/CustomerInfo.wsdl</wsdlURL>
   <operation>getCustomer</operation>
   <service prefix="myeis">CustomerInfoMYEISService</service>
   <port prefix="myeis">CustomerInfo</port>
   <input-parameters>
      <part position="1" name="name"> 
         <schema-type prefix="xs">string</schema-type>
      </part>
   </input-parameters>
   <typeMap>
      <mapping typeClass="org.w3c.dom.Node">
         <xmlType prefix="myeis">
            Customer
         </xmlType>
      </mapping>
   </typeMap>
</wsdl-source>

Java Code This section shows a complete class with Java code for executing the view BasicFileWS, accomplishing the following:

  • Obtain an instance of the XQSFacadeI interface from the XQSFactory factory with the help of the static method getXQSFacade(). .

  • Set up the QueryParameterI array to input the customer name. Obtain an instance of the QueryParameterI interface from the XQSFactory factory with the help of the static method getQueryParameter(). Use the setString() method of the QueryParameterI interface to set the customer name.

  • Execute the view. The view name passed to the executeView() method must match the function name associated with the view in your configuration. Note this method also takes the namespace of the function (also indicated in your configuration). In this example, the view is declared in the XQS namespace.

  • Process errors. Methods of the XQSErrorI interface are used to print out information about any errors encountered during the query. This assumes appropriate XQS error configuration to use the emptySequence or errorMessage mode; otherwise, an error will terminate the query and there will be no useful information in the errors iterator. In this example, as shown earlier in the BasicFileWS configuration, errorMessage mode is used. (See "Using XQS Error Handling Modes and APIs" and "XQSErrorI Reference" for additional information.)

  • Process results. Query results are obtained as instances of class XMLItem (in the oracle.xml.xqxp.datamodel package). Type constants and type-specific accessors of the XMLItem class are used to retrieve values.

  • Close the cursor to free resources associated with the query


Note:

There is no need to declare the XQS function, BasicFileWS, when it is executed directly in an executeView() call.

import oracle.xml.xqxp.datamodel.XMLItem;
import oracle.xml.parser.v2.XMLDocument;
import oracle.xml.parser.v2.XMLElement;
import oracle.xml.parser.v2.XMLNode;
import oracle.xqs.client.XQSFacadeI;
import oracle.xqs.client.XQSErrorI;
import oracle.xqs.client.QueryParameterI;
 
public class XQSFacadeIViewTest {
 
    public static void main(String[] args) throws Exception{
        XQSFacadeI facade = XQSFactory.getXQSFacade();
        String xqueryView = "BasicFileWS";
        QueryParameterI param = XQSFactory.getQueryParameter("custName");
        param.setString("John Ford");
        QueryParameterI[] params = new QueryParameterI[1];
        params[0] = param;
 
        facade.executeView(xqueryView, "http://xmlns.oracle.com/ias/xqs", params);
        
        java.util.ListIterator errors = facade.getErrors();
        while(errors.hasNext()) {
            XQSErrorI error = (XQSErrorI)errors.next();
            System.out.println
               ("The function which gives error is: " + error.getFunctionQName());

            System.out.println("The error type is: "+error.getErrorType()+ " which
               is - "+XQSErrorI.typeNames(error.getErrorType()));
            System.out.println("The error code is:" + error.getErrorCode());
            System.out.println("The error message is:" + error.getErrorMessage());
        }
  
        XMLItem item = facade.getNextItem();
        StringBuffer resultBuf = new StringBuffer();
 
        XMLDocument doc = new XMLDocument();
        XMLElement rootElem = (XMLElement)doc.createElement("QueryResult");
        doc.appendChild(rootElem);
           
        while(item != null) {
        if(item.instanceOfType(XMLItem.XMLITEM_STRING)) {
           resultBuf.append(item.getString());
        }
        else if(item.instanceOfType(XMLItem.XMLITEM_INT)) {
           resultBuf.append(item.getInt());
        }
        else if(item.instanceOfType(XMLItem.XMLITEM_LONG)) {
           resultBuf.append(item.getInt());
        }
        else if(item.instanceOfType(XMLItem.XMLITEM INTEGER)) {
           if(item.intFormat())
               resultBuf.append(item.getInt());           else               resultBuf.append(item.getDecimal().intValue());        }        else if(item.instanceOfType(XMLItem.XMLITEM_BOOLEAN)) {           resultBuf.append(item.getBoolean());        }        else if(item.instanceOfType(XMLItem.XMLITEM_FLOAT)) {           resultBuf.append((float)item.getDouble());        }        else if(item.instanceOfType(XMLItem.XMLITEM_DOUBLE)) {           resultBuf.append(item.getDouble());        }        else if(item.instanceOfType(XMLItem.XMLITEM_XDT_DAYTIMEDURATION)) {           resultBuf.append(item.getDayTimeDuration());        }        else if(item.instanceOfType(XMLItem.XMLITEM_YEARMONTHDURATION)) {           resultBuf.append(item.getYearMonthDuration());        }        else if(item.instanceOfType(XMLItem.XMLITEM_DURATION)) {           resultBuf.append(item.getLexicalValue());        }        else if(item.instanceOfType(XMLItem.XMLITEM_DATETIME)) {           resultBuf.append(item.getCalendar().getTime());        }        else if(item.instanceOfType(XMLItem.XMLITEM_ANYURI)) {           resultBuf.append(item.getString());        }        else if(item.instanceOfType(XMLItem.XMLITEM_DECIMAL)) {           resultBuf.append(item.getDecimal().intValue());        }        else if(item.instanceOfType(XMLItem.XMLITEM_NODE)) {           resultBuf.append(item.getNode().getNodeName());        }        else if(item.instanceOfType(XMLItem.XMLITEM_HEXBINARY)) {           resultBuf.append(item.getString());        }        else if(item.instanceOfType(XMLItem.XMLITEM_BASE64BINARY)) {           resultBuf.append(item.getString());
        }

        item = facade.getNextItem();
        }
        facade.close();
    }
}

Using the EJB Client API

Refer to the "General Coding Steps in Using XQS Client APIs". For the XQS EJB client API, there are differences in the details of these steps depending on whether you choose a stateful session or a stateless session, as follows (after creating your query):

  1. Complete appropriate steps to create a bean instance, such as by executing the lookup, obtaining the EJB local home interface, and creating the local interface. Method calls in the following steps are called from this instance. See the following section, "EJB Clients for Stateful Versus Stateless Sessions", for instructions on how to create a stateful bean versus a stateless bean.

  2. Create a QueryParameterI array for any input parameters and populate it by obtaining instances of the QueryParameterI interface from the XQSFactory factory with the help of the static method getQueryParameter().

  3. Use the execute() method to execute an ad-hoc query, or the executeView() method to execute an XQS view, passing in the query and QueryParameterI array (or null if there are no input parameters). For executeView(), also pass in the namespace of the XQS function for the view.

  4. For a stateful bean, repeatedly use the getNextItem() method to get the results back item by item. Each item is returned in an XMLItem instance. Process these items as desired.

    For a stateless bean, the query results are fully materialized as a vector, java.util.Vector, containing XMLItem instances. Process this vector of items as desired.

  5. If you configured any of the data sources used in the query with the emptySequence or errorMessage error mode, optionally use the getErrors() method to retrieve any errors encountered within those data sources during execution of the query. This returns an iterator over a collection of XQSErrorI objects. See "Using XQS Error Handling Modes and APIs" for information about error configuration and processing.

  6. For a stateful bean, use the close() method to free all resources associated with the query. This is not applicable for a stateless bean.

These steps are shown in examples that follow. Also see "XQS EJB Client API Reference" for reference information.

EJB Clients for Stateful Versus Stateless Sessions

See "Stateful Versus Stateless Clients" for information about when to use a stateful session and when to use a stateless one.

Obtaining a stateful EJB versus a stateless EJB is determined by your JNDI lookup and which XQS package you use. The following example will obtain a stateful bean:

//Look up and create the EJB to execute the query.
InitialContext ic = new InitialContext();
//Use Local client.
oracle.xqs.client.ejb.stateful.XQSClientLocalHome home = 
   (oracle.xqs.client.ejb.stateful.XQSClientLocalHome)ic.lookup
                                        ("java:comp/env/XQSClientStatefulLocal");
oracle.xqs.client.ejb.stateful.XQSClientLocal bean = home.create();

And this example will obtain a stateless bean:

//Look up and create the EJB to execute the query.
InitialContext ic = new InitialContext();
//Use Local client.
oracle.xqs.client.ejb.stateless.XQSClientLocalHome home = 
   (oracle.xqs.client.ejb.stateless.XQSClientLocalHome)ic.lookup
                                        ("java:comp/env/XQSClientStatelessLocal");
oracle.xqs.client.ejb.stateless.XQSClientLocal bean = home.create();

As noted earlier, when you execute a query (ad-hoc or view) in a stateless EJB session, results are fully materialized in a vector containing XMLItem instances, which you then process as desired. For a stateful session, after executing the query, you retrieve items one by one using the getNextItem() method, which returns items of type XMLItem.

Use of the EJB Client API in Stateful Sessions

The XQS EJB stateful client API is the same as the XQSFacadeI API. Beyond the code shown in the preceding section to create the bean, code examples for a stateful EJB client would look like what is shown for XQSFacadeI in "Example 2: XQSFacadeI API with an Ad-Hoc Query" and "Example 3: XQSFacadeI API with an XQS View". Loop repeatedly to use the getNextItem() method to retrieve and process items one by one, as XMLItem instances.

Limitations

The XQS query state associated with stateful EJBs does not survive deactivation and subsequent re-activation. The query state is established after the execute() or executeView() method is invoked. The query state contains internal structures which maintain an execution plan for the query and, after the items get retrieved, the position of the current item in the result sequence. The stateful bean interface enables you to fetch result items one at a time by connecting to the server session each time.

This option is important when the size of each item or the total size of the result sequence is too large to be transferred in one round-trip. It is also useful, when it is desirable to provide a quick first response by bringing back the first item fast. The drawback for this option is that there exists a possibility of a server deactivating the bean and the state of an on-going query being lost.

XQS throws an XQSException with error code XQS 0088 if the query state is lost and a client attempts a subsequent getNextItem() call. One method of alleviating this limitation is to configure queries that are invoked by the stateful bean as cached XQS views. The use of cached XQS views allows queries to be re-executed quickly and the fetch to be resumed from the former current position by performing a number of getNextItem() calls to scroll to the desired position in the result sequence.

Example: EJB Client API with an XQS View in a Stateless Session

This stateless EJB example reuses the BasicFileWS XQS view used in "Example 3: XQSFacadeI API with an XQS View", and repeats some of that code. Refer to that section to see the view and its configuration.

In addition to the JNDI lookup and creation of the stateless bean, the key difference between this stateless EJB example and an XQSFacadeI example is in the result processing. Results for a stateless session are fully materialized into a vector containing XMLItem instances. You then retrieve items one by one from there, casting them as XMLItem, as opposed to there being a getNextItem() method in the bean to retrieve XMLItem instances. The basic nature of the processing remains the same, however.

...
//lookup and create the EJB to execute the xquery
InitialContext ic = new InitialContext();
 
oracle.xqs.client.ejb.stateless.XQSClientLocalHome home =
                 (oracle.xqs.client.ejb.stateless.XQSClientLocalHome)
                 ic.lookup("java:comp/env/XQSClientStatelessLocal");
oracle.xqs.client.ejb.stateless.XQSClientLocal bean = home.create();
 
String xqueryView = "BasicFileWS";
QueryParameterI param = XQSFactory.getQueryParameter("custName");
param.setString("John Ford");
QueryParameterI[] params = new QueryParameterI[1];
params[0] = param;
 
java.util.Vector  result = 
     bean.executeView(xqueryView,"http://xmlns.oracle.com/ias/xqs",params);
 
java.util.Enumeration resultEnum = result.elements();
while(resultEnum!=null && resultEnum.hasMoreElements()) {
    XMLItem item = (XMLItem)resultEnum.nextElement();
    if(item.instanceOfType(XMLItem.XMLITEM_STRING)) {
       resultBuf.append(item.getString());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_INT)) {
       resultBuf.append(item.getInt());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_LONG)) {
       resultBuf.append(item.getInt());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_INTEGER)) {
       if(item.intFormat())
           resultBuf.append(item.getInt());
       else
           resultBuf.append(item.getDecimal().intValue());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_BOOLEAN)) {
       resultBuf.append(item.getBoolean());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_FLOAT)) {
       resultBuf.append((float)item.getDouble());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_DOUBLE)) {
       resultBuf.append(item.getDouble());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_XDT_DAYTIMEDURATION)) {
       resultBuf.append(item.getDayTimeDuration());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_YEARMONTHDURATION)) {
       resultBuf.append(item.getYearMonthDuration());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_DURATION)) {
       resultBuf.append(item.getLexicalValue());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_DATETIME)) {
       resultBuf.append(item.getCalendar().getTime());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_ANYURI)) {
       resultBuf.append(item.getString());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_DECIMAL)) {
       resultBuf.append(item.getDecimal().intValue());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_NODE)) {
       resultBuf.append(item.getNode().getNodeName());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_HEXBINARY)) {
       resultBuf.append(item.getString());
    }
    else if(item.instanceOfType(XMLItem.XMLITEM_BASE64BINARY)) {
       resultBuf.append(item.getString());
    }
// Here is where you might use a bean.getErrors() call and process errors.
// (Assuming appropriate configuration.)
}
...

Using the JSP Tag Library

Refer to the "General Coding Steps in Using XQS Client APIs". For the XQS JSP tag library, there are differences in the details of these steps depending on whether you choose a stateful or stateless access mode, as follows (after creating your query):

  1. Import the XQS JSP tag library through a taglib statement, specifying the TLD URI and desired prefix.

  2. Use an executeCursor tag to execute a query in a stateful mode, or an execute tag to execute a query in a stateless mode. With either an executeCursor or execute tag:

    • Use the xqueryString attribute to specify an ad-hoc query, or the xqsViewName and namespace attributes to specify an XQS view.

    • Define output variables for results of the query: to an XML document (by using the toXMLDoc attribute) and to a java.util.ArrayList instance of results (by using the resultItems attribute). Also, you can optionally output to the JSP output stream (by using the toWriter attribute). Results will be represented by Java object types according to Table 8-2, "XQS Type Support for Bind Parameters".

    • If you configured any of the data sources used in the query with the emptySequence or errorMessage error mode, optionally use the errors attribute to process any errors encountered within those data sources during execution of the query. This will give you an iterator over a collection of XQSErrorI objects. See "Using XQS Error Handling Modes and APIs" for information about error configuration and processing.

  3. In either an executeCursor or execute tag, use a param subtag for each input parameter. Use the param tag localName, namespace, value, and type attributes as appropriate.

  4. With the executeCursor tag, use the related next tag to retrieve results item by item or in batches and place them into the output vehicles.

    With the execute tag, results are fully materialized into the output vehicles.

  5. Loop through one or more output vehicles to process the results. This is not XQS-specific, as the available output vehicles—JSP output stream, XML document, and list of Java objects—are standard. Be aware that results of each execution of next must be processed before next is executed again, because results are overwritten.

  6. With the executeCursor tag, use the close tag to free all resources associated with the query. This is not applicable for the execute tag.

These steps are shown in examples that follow. Also see "XQS JSP Tag Library Reference" for reference information.


Note:

You can also use standard JSTL tags in a JSP page to transform results as desired.

JSP Tags for Stateful Versus Stateless Access

See "Stateful Versus Stateless Clients" for information about when to use stateful access and when to use stateless access.

In a JSP page employing XQS, whether you use stateful access or stateless access is determined by which query tag you use. The executeCursor tag uses stateful access, while the execute tag uses stateless access.

As noted earlier, when you execute a query (ad-hoc or view) in a stateless JSP access pattern, results are fully materialized into the output vehicles you choose through your attribute settings—an XML DOM document and an Object[] array, and optionally the JSP output stream—and then you process those results as desired. For a stateful access pattern, after executing the query, you retrieve and process items one by one using the next tag.

Example: JSP Tags with an XQS View in a Stateful Access Pattern

This stateful JSP example reuses the BasicFileWS XQS view used in "Example 3: XQSFacadeI API with an XQS View". Refer to that section to see the view and its configuration.

The code example in this section does the following:

  • The page directives import required classes.

  • A taglib directive specifies the TLD URI of the tag library, and the desired tag prefix to use.

  • The executeCursor tag executes the view, resulting in an open cursor ready for fetching. The namespace attribute specifies the namespace where the underlying XQSView function is defined.

  • The param subtag of executeCursor specifies the input parameter (customer name).

  • The next tag, associated with the executeCursor tag through the cursorId setting, loops through the results to populate the output vehicles (XML document and result items ArrayList instance), using the itemsFetched attribute each time through as a test of whether any data remains to be processed. The next tag must reference the cursor ID (mycursor) specified in the executeCursor tag.

  • The close tag closes the cursor and frees resources associated with it. This tag must also reference the cursor ID (mycursor) specified in the executeCursor tag.


Notes:

  • Error processing is not shown here. Assuming appropriate error configuration (emptySequence or errorMessage mode in the data source configuration), you could process the myerrors iterator. See "Using XQS Error Handling Modes and APIs".

  • Processing of the output vehicles is not shown here; there is nothing specific to XQS about processing an XML document or array of result objects.


<%@ page import="oracle.xml.parser.v2.XMLElement" %>
<%@ page import="oracle.xml.parser.v2.XMLDocument" %>
 
<%@ taglib uri="http://xmlns.oracle.com/j2ee/jsp/tld/ojsp/xquerytag.tld"
           prefix="xq"%>
<%
String xqueryView = "BasicFileWS";
int items;
%>
<xq:executeCursor
                xqsViewName="<%=xqueryView%>"
                namespace="http://xmlns.oracle.com/ias/xqs"
                resultItems="myresults"
                toXMLDoc="mydoc"
                cursorId="mycursor"
                errors="myerrors" >
   <xq:param
              localName="custName"
              value="John Ford"
              type="String"/>
</xq:executeCursor>
<%
do{
// Populate the XML document and result items array.
%>
   <xq:next
                cursorId="mycursor"
                itemsFetched="fetched" />
<%
  items=fetched.intValue();
 }while(items>0)
// Here is where you might process the "myerrors" error iterator.
// (Assuming appropriate configuration.)

// Retrieve results from the XML document mydoc and the result items array myresults.
// (This processing is not XQS-specific.)
%>
<xq:close cursorId="mycursor" />

Example: JSP Tags with an Ad-Hoc Query in a Stateless Access Pattern

This example uses the XQS JSP execute tag to execute an ad-hoc query, and a stateless access pattern is used. The intent is primarily to compare and contrast the following, compared to the preceding example using stateful access:

  • Use an ad-hoc query instead of a view. See "Example 2: XQSFacadeI API with an Ad-Hoc Query", which uses the same query, for relevant configuration. The query is pieced together in a string buffer, then written from there to a string.

  • Use the execute tag, for stateless access, instead of the executeCursor tag, for stateful access. Note that there is no next subtag for an execute tag, and the close tag is not required.

<%@ page import="oracle.xml.xqxp.datamodel.XMLItem" %>
<%@ page import="oracle.xml.parser.v2.XMLElement" %>
<%@ page import="oracle.xml.parser.v2.XMLDocument" %>
 
<%@ taglib uri="http://xmlns.oracle.com/j2ee/jsp/tld/ojsp/xquerytag.tld"
           prefix="xq"%>
<%
StringBuffer xqueryBuf = new StringBuffer();
xqueryBuf.append("declare namespace xqs=\"http://xmlns.oracle.com/ias/xqs\";\n");
xqueryBuf.append("declare function xqs:get_poSQ($bind as xs:string) external;\n");
xqueryBuf.append("for $po in xqs:get_poSQ(\"http://localhost:8888/myrepository/pos-2KB.xml\") \n");
xqueryBuf.append("return $po\n");

String xqueryStr = xqueryBuf.toString();
%>
<xq:execute
                xqueryString="<%=xqueryStr%>"
                toXMLDoc="mydoc"
                resultItems="myresults"
                errors="myerrors" />
<%
// Here is where you might process the "myerrors" error iterator.
// (Assuming appropriate configuration.)
%>
<%
// Retrieve the results from either the XML document mydoc or result items array
// myresults. (This processing is not XQS-specific.)
%>

Using an XQS View Exposed as a Web Service Operation

XQS can expose an XQS view as a Web service operation, with the Web service being implemented through a servlet that is generated automatically. This and related details are described in "OC4JPackager Additional Output to Expose XQS Views As Web Service Operations".

Note that you must provide the Web service client yourself.

How to Use OC4JPackager to Package Your XQS Application

This section describes how to use OC4JPackager to bundle XQS-related files with your application. See "Introduction to OC4JPackager" for an overview.

OC4JPackager produces an EAR file that you can deploy to OC4J as you would any other EAR file. See the Oracle Containers for J2EE Deployment Guide for general information.

The following topics are covered here:

Steps in Using OC4JPackager

This section covers the basic preparatory and execution steps when you have a J2EE application and want to run OC4JPackager to enable it to use XQS features. See "OC4JPackager Reference" for general information about the OC4JPackager parameters and Java properties mentioned here.


Note:

OC4JPackager does not support directory or file names with spaces.

Preparing to Run OC4JPackager

Complete these steps to prepare to run OC4JPackager:

  1. Create JAR files for your application components as usual—WAR files for Web modules, EJB JAR files for EJB modules, and so on, all with the applicable standard J2EE configuration files (such as web.xml and ejb-jar.xml). You then have the option of bundling them into an EAR file for OC4JPackager to access, or leaving them and any other relevant files (such as application.xml) in a directory structure reflecting the structure and contents of an EAR file.

  2. Choose a desired directory for your application, and place the EAR file or structured EAR contents (as applicable) in that directory.

    You will specify that directory to OC4JPackager through the -appArchives parameter (required).

  3. Choose a desired directory as your XQS repository, where any XQS view (.xq or .sql) files are located, and place the XQS view (.xq or .sql) files there.

    You can specify that directory to OC4J Packager through the -repository parameter.

  4. Assuming you have completed your XQS configuration (see "How to Configure Your XQS Functions"), choose a desired directory for the xqs-config.xml file and place the file in that directory.

    You will specify that directory to OC4JPackager through the -xqsConfig parameter (required).

Running OC4JPackager: Required and Optional Parameters and Properties

Specify the following, as applicable, when you run OC4JPackager. See the next section, "Running OC4JPackager on the Command Line", for examples.

Program Parameters

  1. Use the required -appArchives parameter to specify the directory where your application is located (where the EAR file is, or the top-level directory of an EAR structure).

  2. Use the optional -repository parameter to specify the directory for your XQS repository.

  3. Use the required -xqsConfig parameter to specify the full path of your application xqs-config.xml file, including the file name.

  4. Use the required -name and -output parameters to specify the desired name and output directory of the EAR file that OC4JPackager will produce.

  5. Use applicable flags to have OC4JPackager include files for XQS features that your application uses, or to exclude files:

    • Use the -jsp flag if you use the XQS JSP tag library.

    • Use the -sf flag if you use the XQS stateful EJB client API.

    • Use the -sl flag if you use the XQS stateless EJB client API.

    • Use the -no_ws flag to prevent OC4JPackager from generating Web services.

    (The XQSFacadeI interface is always included.)

Java VM Properties

  1. Use the required Java property java.home to specify your Java home directory, from which OC4JPackager will run the java command for its tasks.

  2. Use the optional Java property xds.packager.work.dir if you want to have OC4JPackager use a particular working directory (where it unbundles and bundles EAR files as needed). The default is the directory specified by the user.home Java property.

  3. Use the optional Java property java.util.logging.properties.file to specify a logging properties file where you can specify Java logging settings, including the OC4JPackager logging level. Logging properties are defined by standard J2SE logging, as described in the following guide:

    http://java.sun.com/j2se/1.4.2/docs/guide/util/logging/
    
    
  4. Use the optional Java property oracle.home if you want to indicate your Oracle home directory. You must do this to use OC4JPackager flags -jsp, -sf, and -sl (described in "OC4JPackager Parameters") and related JAR files.

Running OC4JPackager on the Command Line

You can run OC4JPackager from a command line by using the java command to execute OC4JPackager.jar (where % is the command prompt):

% java -jar OC4JPackager.jar ...

OC4JPackager.jar is in the xqs/tools directory of your XQS distribution and must be used from its installed location in the OC4J container.

Here is an example (where $ORACLE_HOME has been set as the home directory of your Oracle installation, and "\" indicates line wrap). This is for an application that uses the XQS JSP tag library and stateful EJB client API. Note that you can specify paths that are either relative to your current directory or absolute.

% java -jar OC4JPackager.jar \
       -Djava.home=/home/myjavainstall \
       -Dxds.packager.work.dir=$ORACLE_HOME/temp \
       -Doracle.home=$ORACLE_HOME \
       -Djava.util.logging.properties.file=myfile.properties \
       -appArchives $ORACLE_HOME/myapp \
       -xqsConfig $ORACLE_HOME/xds/myconfig/xqs-config.xml \
       -repository $ORACLE_HOME/xds/repository \
       -output $ORACLE_HOME/xds/mystaging -name myxqsapp.ear \
       -jsp -sf

Alternatively, you can run OC4JPackager through Ant, as described in the next section.

Also see "OC4JPackager Basic Output".

Running OC4JPackager Through Ant

As an alternative to running OC4JPackager from a command line, as described in the preceding section, you can run it as part of a build process using Ant, through the standard Ant java task. Refer to the Apache Web site http://ant.apache.org/manual/ for general information about Ant. (In addition, if you are interested, see the Oracle Containers for J2EE Deployment Guide for information about OC4J-specific Ant tasks.)

The following example from an Ant build file executes OC4JPackager, and corresponds to the command-line example shown in the preceding section:

<java jar="OC4JPackager.jar" fork="true" failonerror="true">
   <jvmarg value="-Doracle.home=${ORACLE_HOME}"/>
   <jvmarg value="-Djava.home=/home/myjavainstall"/>
   <jvmarg value="-Dxds.packager.work.dir=${ORACLE_HOME}/temp"/>
   <jvmarg value="-Djava.util.logging.properties.file=myfile.properties"/>
   <arg line="-appArchives ${ORACLE_HOME}/myapp"/>
   <arg line="-xqsConfig ${ORACLE_HOME}/xds/myconfig/xqs-config.xml"/>
   <arg line="-repository ${ORACLE_HOME}/xds/repository"/>
   <arg line="-output ${ORACLE_HOME}/xds/mystaging" />
   <arg line="-name myxqsapp.ear"/>             
   <arg line="-jsp"/>
   <arg line="-sf"/>
</java>

Important:

In the <arg> elements to set OC4JPackager parameters, use the line attribute, as shown, as opposed to the value attribute.

OC4JPackager Basic Output

The EAR file produced by OC4JPackager has the standard structure, with at least one additional component—a file named xqs-resources.jar that contains the XQS configuration file and a directory with the XQS repository files (.xq files for XQS views).


Note:

The EAR file will contain additional components if you have XQS views that you are exposing as Web service operations. See the next section, "OC4JPackager Additional Output to Expose XQS Views As Web Service Operations".

For an application consisting of a Web module mywebapp and EJB module myejb, here are the contents of the EAR file that OC4JPackager would produce:

META-INF/
   application.xml
   orion-application.xml
   data-sources.xml
mywebapp.war
myejb.jar
xqs-resources.jar

Aside from xqs-resources.jar, your application must already include the application.xml file, plus optional orion-application.xml and data-sources.xml files, if needed, WAR files for any Web modules, EJB JAR files for any EJB modules, and so on.

The structure of xqs-resources.jar is as follows:

APP-REPOSITORY/
      filename.xq
      filename.xq
      filename.xq
      ...
   xqs-config.xml
   xds-application.properties

The file xds-application.properties is for internal use by XQS.

OC4JPackager Additional Output to Expose XQS Views As Web Service Operations

For any XQS view with a setting of WSDLvisibility="true" in the XQS configuration, except a SQL-based view, XQS exposes the view as a Web service operation. You must have a Web service client to invoke the operation, as for any Web service.


Note:

If you want to prevent OC4JPackager from creating and adding a Web service module to your application, which would expose your XQS views with the WSDLvisibility property set to true as Web service operations, specify the -no_ws flag when you run the packager, as follows:

% java -jar OC4JPackager.jar ... -no_ws

This flag is optional. By default, a Web service module will be added.


OC4JPackager creates an implementation of the Web service and a WSDL document that defines an operation for each XQS view to be exposed. OC4JPackager then produces a WAR file with contents including the following:

  • The WSDL document

  • Web module configuration file web.xml, to configure the Web service servlet

  • Web services configuration file oracle-webservices.xml

OC4JPackager also updates the application.xml file for your application, to make an entry for the additional Web module.

The name of the additional Web module, representing the XQS View Web service, as well as the context root and the WAR file correspond to the name of your application, such as the following for an application myapp:

  • /myapp-WS—the context root of the Web services module

  • myapp-WS-web.war

The generated WSDL file is always named xqsview-WS.wsdl.

The URL pattern for the servlet representing the Web service (and leading to the Oracle Web service test page) is always /xqs-ws.

Thus, the URL for the WSDL of the XQS view Web service is http://host:port/myapp-WS/xqs-ws?WSDL.


Note:

The additional WAR file does not contain client invocation code for Web services. It is intended to be part of your application deployment on the server.

In the WSDL document, the wsdl:operation will have the same name as the corresponding XQS function name defined in the XQS configuration (in the <function-name> subelement of <xqsview-source>). Each wsdl:input message type maps to the XML types corresponding to the input parameter types defined in the XQS configuration (under the <input-parameters> subelement of <xqsview-source>). The wsdl:output message type maps to the XML element or type corresponding to the output element defined in the XQS configuration (in the <output-element> subelement of <xqsview-source>). These can be either simple types, such as string or int, or complex types defined by users. The bindings will be SOAP doc/wrapped bindings.

The following sections together provide an example:

Example: Configuration to Expose a View As a Web Service Operation

The following configuration, seen earlier in this chapter, exposes the view BasicFileWS as a Web service operation, through the setting WSDLvisibility="true".

<xqsview-source WSDLvisibility="true"  isCached="false">
   <function-name  prefix="xqs">BasicFileWS</function-name>
   <input-parameters type-match="none" >
      <part position="1" name="custName">
         <schema-type prefix="xs">string</schema-type>
      </part>
   </input-parameters>
   <output-element namespace="http://xmlns.oracle.com/ias/xqs/CustomerDemo" 
                location="http://host:port/xqsdemos/MyTypes.xsd" type=CustomerOrdersType>customerOrders </output-element>
</xqsview-source>

Assume, for ensuing discussion, that this is part of an application called myapp.

Example: EAR File for a View Exposed As a Web Service Operation

Assume an application, myapp, comprises mywebapp.war and myejb.jar and exposes one or more XQS views as Web service operations. Here are the relevant contents of the application EAR file after we run OC4JPackager:

META-INF/
   application.xml
mywebapp.war
myejb.jar
myapp-WS-web.war
xqs-resources.jar

The WAR file myapp-WS-web.war is for the automatically created servlet implementation of the Web service operations for any exposed views. See the next section for its contents.

Example: WAR File for a View Exposed As a Web Service Operation

Here are the contents of myapp-WS-web.war, created for a servlet implementation of the Web service operations for any exposed views:

WEB-INF/
   web.xml
   oracle-webservices.xml
   wsdl/
      xqsview-WS.wsdl

In particular, note the WSDL document. Sample fragments of the WSDL are shown in the next section, "Example: WSDL Document for a View Exposed As a Web Service Operation".

Example: WSDL Document for a View Exposed As a Web Service Operation

This section shows fragments of a WSDL document generated by the OC4JPackager for an XQS view being exposed as a Web service. This example focuses on fragments relating to a view named BasicFileWS.

...
<definitions xmlns="http://schemas.xmlsoap.org/wsdl/"
    xmlns:xqscwsNsPref="xqs-client-ws"
    xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
    xmlns:xqs0="http://xmlns.oracle.com/ias/xqs" xmlns:tns="xqs-
    client-ws_myapp-WS" name="myapp-WS" targetNamespace="xqs-
    client-ws_myapp-WS">
<types>
...
<schema targetNamespace="http://xmlns.oracle.com/ias/xqs"
xmlns:xqs1="http://xmlns.oracle.com/ias/xqs/CustomerDemo" 
xmlns:tns="http://xmlns.oracle.com/ias/xqs"
...
>
<import namespace="xqs-client-ws"/>
<import namespace=Óhttp://xmlns.oracle.com/ias/xqs/CustomerDemoÓ 
schemaLocation=Óhttp://host:port/xqsdemos/MyTypes.xsdÓ/>
 
<complexType name="BasicFileWSType">
      <sequence>
          <element name="custName" type="string" 
              nillable="true" /> 
      </sequence>
   </complexType>
   <complexType name="BasicFileWSResultType">
       <sequence>
         <element name="return" nillable="true">
           <complexType>
             <sequence>
               <element name="result" nillable="true">
                 <complexType>
                   <sequence>
                     <element name="customerOrders"
                        type="xqs1:CustomerOrdersType"
                        minOccurs="0" maxOccurs="unbounded" />
                  </sequence>
                 </complexType>
               </element>
             <element name="errors" nillable="true" minOccurs="0">
               <complexType>
                 <sequence>
                    <element name="xqserror" 
                      type="xqscwsNsPref:XQSErrorType" 
                      maxOccurs="unbounded" /> 
                  </sequence>
                </complexType>
              </element>
            </sequence>
          </complexType>
        </element>
      </sequence>
    </complexType>
<element name="BasicFileWS" type="tns:BasicFileWSType" /> 
<element name="BasicFileWSResult" type="tns:BasicFileWSResultType" /> 
       
…
</schema>
…
</types>
…
<message name="BasicFileWSRequest">
 <part name="parameters" element="xqs0:BasicFileWS" />
</message>
<message name="BasicFileWSResponse">
 <part name="return" element="xqs0:BasicFileWSResult" /> 
</message>
…
<portType name="XQSViewWebServices">
   <operation name="BasicFileWS">
      <input message="tns:BasicFileWSRequest" /> 
      <output message="tns:BasicFileWSResponse" /> 
    </operation>
    …
    </portType>
      <binding name="HttpSoap11Binding"  type="tns:XQSViewWebServices">
          <soap:binding style="document"
            transport="http://schemas.xmlsoap.org/soap/http" /> 
        <operation name="BasicFileWS">
           <soap:operation /> 
          <input>
              <soap:body use="literal" parts="parameters" /> 
           </input>
          <output>
              <soap:body use="literal" parts="return" /> 
           </output>
         </operation>
         …
    </binding>
   <service name="XQSView-WS">
       <port name="HttpSoap11" binding="tns:HttpSoap11Binding">
           <soap:address xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
             location="http://host:port/myapp-WS/xqs-ws" /> 
       </port>
   </service>
</definitions>

Using XQS Performance Features

This section discusses performance features that XQS offers. The following topics are covered:

Performance Considerations for Using the XQS Stateless or Stateful Client APIs

As noted previously, the XQS client APIs give you the choice of stateless query execution, where results are fully materialized into process memory, or stateful query execution, where results are accessed incrementally through a cursor. Each approach has advantages and disadvantages.

For most situations, stateless execution is preferable because associated resources are freed immediately after the evaluation is completed. Stateless execution, however, is not feasible when the total size of items in the result sequence may be too large, such that materializing the whole sequence at one time would run out of process memory. In this case, cursor mode is the only option, as long as nothing (such as an aggregate expression) prevents the query from providing the results item-by-item.

See "Stateful Versus Stateless Clients" for additional information.

Configuring XQS Caching

This section covers the details of how to configure the cache when using XQS, and discusses related considerations:


Important:

The XQS implementation uses the OC4J Java Object Cache for its caching. The Java Object Cache must be running (and will be started automatically if necessary), and its configuration file, ORACLE_HOME/j2ee/home/config/javacache.xml, must be present. There is generally no need for you to update this file directly, but you have that option. See Chapter 7, "Java Object Cache".

Be aware that any configuration of the Java Object Cache applies across the OC4J instance, not just to your XQS application.


XQS Cache Settings

XQS caching is configured individually for each XQS function (essentially, for each data source that you access). Use the steps that follow to employ caching for any particular XQS function.

Strategies to consider are discussed in the next section, "XQS Caching Strategies". Complete documentation for all the elements and attributes mentioned here is under "XQS Configuration File Reference".

  1. Enable caching through the isCached attribute of the <document-source>, <xqsview-source>, or <wsdl-source> element. For example:

    <document-source isCached="true">
       ...
    </document-source>
    

    Important:

    If isCached has a value of "false" (the default), all other cache settings for the XQS function are ignored.

  2. Use the <cache-properties> subelement of <document-source>, <xqsview-source>, or <wsdl-source>. The time-to-live attribute takes an integer value to determine how long, in seconds, cache entries are maintained before expiring. For example:

    <cache-properties time-to-live="600">
          ...
       </cache-properties>
    
    
  3. Use the <in-memory> subelement of <cache-properties> to specify which cache mode to use, through the useSpool and useDiskCache attributes. For plain memory-based caching, set useSpool and useDiskCache both to "false". For memory-based caching with the capability of spooling cached data to disk as necessary in case of any memory shortage, set useSpool to "true" and useDiskCache to "false". For disk-based caching, set useDiskCache to "true" and useSpool to "false". (See "XQS Caching Strategies", immediately following this section, for related considerations.) The following example uses memory-based caching, but with spooling if necessary:

    <in-memory useSpool="true" useDiskCache="false"/>
    
    

Here is the complete cache configuration example:

<document-source isCached="true">
   ...
   <cache-properties time-to-live="600">
      <in-memory useSpool="true" useDiskCache="false"/>
   </cache-properties>
   ...
</document-source>

XQS Caching Strategies

Note the following considerations for XQS caching:

  • In situations where data is expensive in any way (in time, in terms of any other possible access costs, or in terms of application overhead), you should probably cache your sources. You should also consider the possible impact of caching on the OC4J instance system memory, but memory effects can be alleviated through disk-based caching, or memory-based caching with spooling. (These are discussed in the section that follows.)

  • In order to cache query results, define a query as an XQS view. A view, being a type of XQS source, can be cached (meaning its results are cached).

  • Expiration, or time-to-live, of cached objects is at your discretion. The nature of the data, and how old it can be without losing its usefulness, determines how long it should be cached before expiring.

  • In defining your <in-memory> settings, consider whether to use plain memory-based caching (useSpool="false" and useDiskCache="false"); memory-based caching with spooling to disk, in case that is necessary due to memory shortage (useSpool="true" and useDiskCache="false"); or disk-based caching (useSpool="false" and useDiskCache="true"). See "<in-memory>" for additional information. Note the following:

    • Plain memory-based caching has the fastest performance but the greatest risk of loss of cached data, due either to memory shortage or server failure.

    • Memory-based caching with spooling is faster than disk-based caching (unless memory issues result in cached data always being spooled), but risks the loss of cached data in case of server failure.

    • Disk-based caching has the slowest performance, but the greatest safety for cached data. There are no memory concerns, and cached data is recovered in the event of server failure.

    Balance the criticality of cached data versus the importance of execution speed.

Caching and Nondeterministic Results

Be aware that the issue of XQS functions and node identity, described in "Requirements, Limitations, and Special Notes", may be relevant in some unusual or atypical situations, resulting in differing query results depending on whether caching is used. Generally this is not an issue, however, as the great majority of queries depend on equality between values, not between nodes.

Configuring XQS Document Sources for Large Data

There are situations where data sets are so large that memory limitations are encountered regardless of system capacity or the use of typical memory conservation. A solution for this is to use a "working unit" approach behind the scenes, where a constant amount of memory is used regardless of the total amount of data being retrieved. XQS is cooperating with dependent technologies in the Oracle XDK and middle-tier XQuery to provide such a scalable solution whenever you are running XQS.

There are also situations, however, where data sets are large enough that even the "working unit" approach is insufficient. In these circumstances, for document sources, you can provide a hint to XQS that the data source may take up sizable memory resources, and that XQS should use memory-saving internal optimizations. Use the largeData flag—an attribute of the <document-source> element—as in the following example:

<document-source largeData="true">
   ...
</document-source>

If you have trouble loading a large document source into memory, enabling this flag may allow you to proceed.


Important:

  • The largeData flag does not apply to XQS views and WSDL sources.

  • With largeData="true", you may experience degradation in speed. Use this setting only when necessary. For this reason, the default value is "false".


Using XQS Error Handling Modes and APIs

As noted in "Introduction to XQS Error Handling", you can configure XQS functions to continue even if they encounter errors (such as data source unavailability or data conversion problems). If you do configure XQS functions to continue, you can then retrieve the errors, which are returned as an iterator over oracle.xqs.client.XQSErrorI objects, and obtain information about the errors.

XQS applies special handling only to errors inside an XQS function. A regular XQuery error, such as a syntax error or type mismatch, terminates query execution regardless of the XQS error mode.

You configure the XQS error mode for each XQS function individually. The error mode for one function does not have any effect on the behavior of other XQS functions in the same query.

The following sections discuss how to configure XQS functions to continue and return error information, and what methods are available to retrieve that information:

Configuring XQS Function Error Handling

For each data source you configure in xqs-config.xml, you can specify XQS error-handling through the onError attribute of the source element—<document-source>, <xqsview-source>, or <wsdl-source>. The following settings are supported.

  • dynamicError (default): With this setting, XQS raises an XQuery dynamic error and the query is terminated if any problem is encountered during evaluation of the XQS function. In this circumstance, no error objects are returned; you cannot retrieve any information beyond the exception message itself.

  • emptySequence: With this setting, in the event of an error generated by the XQS function, the function returns an empty XML sequence as its result, and the query execution can continue. You can retrieve error objects and obtain information from them as discussed in the sections that follow.

  • errorMessage: With this setting, in the event of an error generated by the XQS function, the function returns a one-item XML sequence for the function result. The item in the sequence represents an error message—either a preconfigured message or whatever message the data source returns, depending on your configuration. You can also retrieve error objects and obtain information from them as discussed in the sections that follow.

So there are possibly two steps in configuring your XQS error-handling for a particular data source:

  1. Specify the desired setting of the onError attribute in the <document-source>, <xqsview-source>, or <wsdl-source> element.

  2. If you are using errorMessage mode, optionally use the <error-message> subelement of <document-source>, <xqsview-source>, or <wsdl-source>. This will preconfigure an error message for XQS to place in the one-item XML sequence that is returned for the query result.

Here is an example for a source that uses emptySequence mode:

<document-source onError="emptySequence">
   ...
</document-source>

And here is an example that uses errorMessage mode with a preconfigured message:

<wsdl-source onError="errorMessage">
   ...
   <error-message>No information available</error-message>
   ...
</wsdl-source>

In errorMessage mode, if you do not specify a preconfigured message (in other words, if you do not use an <error-message> element), then XQS will take whatever message is returned by the data source, and put that message in the one-item XML sequence that is returned as the function result. Occasionally it will be impossible to obtain any meaningful error message from a data source with poor error-reporting facilities. In that case, if you did not provide a preconfigured message, the error message returned will be empty.

The single item in the sequence returned can be of one of two types: xs:string or xs:node.

  • If the item is a string, the string is simply the error message, either preconfigured or taken from the actual error that occurred.

  • If the item is an XML node, it will be called xqserror and its text value will be the error message. In addition, the error node will have three attributes: functionName, type and code. The XQS error node looks like this:

<xqserror functionName="XQS function name" type="XQSERR_XXX" code="XQS 0NNN" >
   error message
</xqsrror>

XQS chooses a more appropriate type for the error item based on the type information it has about the function:

  • If the XQS function is a Document function, the error item will be of type xs:node. This is because a Document function is always expected to return an XML node.

  • If the XQS function is configured with <output-element>, and the type or element name is not a primitive XML Schema type, XQS assumes that the function is an XML element type and creates the error item as an XML node.

  • If <output-element> specifies a primitive XML Schema type (even if it is not xs:string), or if <output-element> is not provided, then XQS creates the error item as a string.

Notes and Considerations

  • If you configure an XQS function with the errorMessage error mode and you do not provide <output-element>, or you provide <output-type> and it is not a user-defined complex type or xs:string, do not specify a return type for the function in the XQuery prolog of the queries that use this function. Declaring a return type for external XQuery functions is optional. If you specify the return type under the preceding circumstances, XQuery enforces this return type at runtime. If an error occurs during execution of the XQS function, XQS will return the error message as a string, and this will conflict with the return type declared in the query prolog. If you do not declare the return type, the type match will not be enforced.

  • For a situation in which an XQS view uses other XQS functions and sources, error-handling configuration of the view and of the underlying functions are relevant. Configuration of any underlying function determines how the function behaves when an error is encountered—whether it terminates with a dynamic error, or continues and returns a predetermined value (either an empty sequence or an error message). Configuration of the view itself determines whether to stop or to continue the query associated with the view when an error is encountered, including but not limited to errors raised by any underlying functions.

  • For an <xqsview-source> element that defines <output-element>, check if any XQS function in the underlying query, or in a query nested though the use of another <xqsview-source> function, defines an "errorMessage" error-handling option. Every such nested <xqsview-source> function with the onError="errorMessage" option must provide an appropriate <output-element> definition. If this requirement is not met and an error occurs in the nested XQS view function, XQS will create a return value of the type xs:string for that function. This would violate the declared type of the outermost XQS view function and create additional XQuery errors due to a type mismatch.

    Other error-handling options are not subject to this requirement.

  • When an error occurs in the default dynamicError mode, XQS clients propagate the exception as follows: an EJB will return an EJB exception; an XQSFacadeI instance will throw an XQS exception wrapping the XQuery exception; a JSP tag will throw a JSP tag exception which can be handled through the standard JSP errorPage attribute.

  • In addition to creating error objects (discussed in the following section "Retrieving XQS Error Objects", XQS reports errors to OC4J log files according to your overall OC4J logging configuration. You can search for XQS error, warning, or information messages in the relevant log file (such as ORACLE_HOME/j2ee/home/log/oc4j/log.xml). See Oracle Containers for J2EE Configuration and Administration Guide for general information about OC4J logging.

Retrieving XQS Error Objects

Assuming an XQS function is configured to use the emptySequence or errorMessage error-handling mode, you can use features of the XQS client APIs to retrieve an iterator of error objects, from which you can obtain information about any problems that occurred during the query. Here is a quick summary:

  • If you use the XQSFacadeI interface or either of the XQS EJB APIs (stateful or stateless), use the following method to retrieve an iterator containing error objects:

    java.util.ListIterator getErrors()
    
    
  • If you use the XQS JSP tag library (stateful or stateless), specify the desired variable name as the value of the errors attribute of the execute or executeCursor tag. The JSP tag implementation creates the ListIterator variable and populates it with an iterator containing error objects.

In either case, you will have an iterator containing oracle.xqs.client.XQSErrorI objects. Here is an example:

...
XQSFacadeI bean = XQSFactory.getXQSFacade();
...
bean.executeView(viewname, namespace, queryparams);
...
ListIterator errorIt = bean.getErrors();
XQSErrorI error = null;
while(errorIt.hasNext()) {
   error = (XQSErrorI)errorIt.next();
   (Process errors)
}
...
bean.close();
...

And here is a JSP example:

XQSErrorI error=null;
...
<xq:executeCursor ... errors="errorIt" ... >
   ...
</xq:executeCursor>
...
<xq:next ... />
while(errorIt.hasNext()) {
   error = (XQSErrorI)errorIt.next();
   (Process errors)
}

See the next sections, "Obtaining Information from XQS Error Objects" and "Example: Error Retrieval and Processing", for information and examples for obtaining error information.

Obtaining Information from XQS Error Objects

The preceding section, "Retrieving XQS Error Objects", describes how to obtain a java.util.ListIterator instance consisting of oracle.xqs.client.XQSErrorI objects.

You can process the iterator instance to obtain the individual XQSErrorI objects. The ListIterator type includes the following methods:

  • Object next(): This returns the next element in the iterator. You can cast each element to the XQSErrorI type.

  • boolean hasNext(): This returns true if there are elements remaining.

You can then use the individual XQSErrorI instances to obtain information about each error that occurred during a query.


Notes:

  • XQS returns XQSErrorI objects only if you configure one or more XQS functions used in your query with a nondefault emptySequence or errorMessage mode. If no errors occurred, ListIterator will be empty.

  • The XQSErrorI Java object should not be confused with the error item of type xs:node, which XQS sometimes constructs as a return value for an XQS function in the case of an error, as described in "Configuring XQS Function Error Handling".. XQSErrorI is a Java object, as opposed to an XML node. XQSErrorI objects are returned to the client of XQS, whereas the XML error node is returned to the XQuery execution. Finally, XQSErrorI objects are returned even if the error mode is emptySequence, whereas an XML error node is constructed only when the error mode is errorMessage.


This section summarizes the XQSErrorI methods for obtaining error information, and also summarizes XQS error types. For complete information, see "XQSErrorI Reference".

With each XQSErrorI instance, you can do the following. Assume an XQSErrorI instance, xqserr, for these examples:

  1. Obtain the qualified name of the XQS function that returned the error:

    String funcname = xqserr.getFunctionQName();
    
    
  2. Obtain the error type (see the following section for types):

    int errortype = xqserr.getErrorType();
    
    
  3. Obtain string representation of the error type:

    String typeStr= XQSErrorI.typeNames(xqserr.getErrorType()
    
    
  4. Obtain the error message:

    String errormessage = xqserr.getErrorMessage();
    
    
  5. For data sources that provide error codes separately from error messages (such as ORA-xxxxx codes from an Oracle database), obtain the error code:

    String errorcode = xqserr.getErrorCode();
    
    
  6. Optionally use utility methods to combine the function name, error type, error message, and error code into a single string, an XML string (a string that includes appropriate XML markup), or an XML node:

    String errorstring = xqserr.toString();
    ...
    String errorxmlstring = xqserr.toXMLString();
    ...
    org.w3c.dom.node errornode = xqserr.toXMLNode();
    
    

Here is a summary of the integer constants for error types:

  • XQSERR_MISSING_SRC: Data source not found.

  • XQSERR_SRC_ACCESS: Data source found but returns an access error (such as invalid login).

  • XQSERR_SRC_ERROR: Data source found and accessed but returns some other error.

  • XQSERR_PARAM: Problems encountered in passing bind parameters to the source, or receiving output parameters from the source.

  • XQSERR_SRC_CONFIG: Problems encountered in processing XQS configuration.

  • XQSERR_INTERNAL: XQS encountered unexpected internal error.

See "XQSErrorI Reference" for additional information about these constants.

Example: Error Retrieval and Processing

This section shows a simple error-processing example with corresponding configuration.

Configuration To use XQSErrorI objects in an XQS application (as discussed earlier, in "Configuring XQS Function Error Handling"), the data source must be configured for error mode emptySequence or errorMessage. The following example uses errorMessage mode:

<xqsview-source ... onError="errorMessage">
   <function-name prefix="xqs">BasicFileWS</function-name>
<output-element namespace="myNS">myElement</output-element>
   ...
</xqsview-source>

Because no <error-message> element is used, the one-item XML result sequence that is returned will forward whatever message comes from the data source, rather than containing a predefined message. If the XQS view function, in fact, encounters an error, XQS will construct an <xqserror> XML node and return it as the function result. The error message will be the text value of the <xqserror> node. XQS chooses the XML node representation because the XQS view configuration specifies a user-defined element in its <output-element> configuration.

Java Code Following is a sample code fragment that executes a view and then does the following error processing:

  • Calls the getErrors() method of the XQSFacadeI interface to retrieve a java.util.ListIterator instance of XQSErrorI objects.

  • Uses the ListIterator class hasNext() method to determine how many error objects to iterate through.

  • For each error, prints the qualified name of the XQS function that produced the error, then prints the error type, error message, and error code.

...
XQSFacadeI bean = XQSFactory.getXQSFacade();
String xqueryView = "BasicFileWS";
QueryParameterI param = XQSFactory.getQueryParameter("custName");
param.setString("John Ford");
QueryParameterI[] params = new QueryParameterI[1];
params[0] = param;
bean.executeView(xqueryView, null, params);
while(bean.getNextItem() !=null) {
}
ListIterator errors = bean.getErrors();
while(errors.hasNext()) {
   XQSErrorI error = (XQSErrorI)errors.next();
   System.out.println("The function which gives error is: " +
                        error.getFunctionQName());
   System.out.println("The error type is:"  + error.getErrorType()) +
", which means " +XQSErrorI.typeNames(error.getErrorType()));

   System.out.println("The error message is:" + error.getErrorMessage());
   System.out.println("The error code is:" + error.getErrorCode());
}
...

Using XQS in a BPEL Environment

XQuery and XQS can be used from an Oracle BPEL Process Manager running on Oracle Application Server.


Note:

This section refers to concepts used in Oracle BPEL Process Manager. Only concepts that are specific to the use of XQuery and XQS in Oracle BPEL are described in this section. For more information on general BPEL and Oracle BPEL concepts mentioned here, refer to the Oracle BPEL Process Manager Developer's Guide.

Oracle BPEL provides an XPath function that enables the Oracle BPEL Process Manager to invoke XQuery-based XML queries. The queries can be stored as XQS views. XQS views can be organized into folders (up to two levels deep) and namespaces. XQS views allow better application modularity as well as the ability to create complex queries by calling one XQS view from another.


Note:

Queries invoked from the BPEL environment behave similarly to XQS views. However, the functionality available in the BPEL environment is limited compared to XQS views used in a generic J2EE application running on an Oracle Application Server.

This section covers these topics:

Registering the BPEL XPath Function for XQuery

Oracle BPEL provides a Java class (com.collaxa.cube.xml.xpath.functions.xml. GetElementFromXQueryFunction) that is registered in the orabpel\domains\default\config\xpath-functions.xml file as follows:

<function id="processXQuery">
   <classname>
      com.collaxa.cube.xml.xpath.functions.xml.GetElementFromXQueryFunction
   </classname>   <comment>
      <![CDATA[This function returns result of XQuery execution. The
         signature of this function is
         <i>ora:processXQuery('view_name','context_node'?)</i>.]]>
   </comment>
   <property id="namespace-uri">
      <value>http://schemas.oracle.com/xpath/extension</value>
      <comment>Namespace URI for this function</comment>
   </property>
   <property id="namespace-prefix">
      <value>ora</value>
      <comment>Namespace prefix for this function</comment>
   </property>
</function>

This example assumes that you have placed the GetElementFromXQueryFunction.class file into the orabpel\system\classes\com\collaxa\cube\xml\xpath\functions\xml directory. The ora:processXQuery function is now used like any other XPath function in the BPEL process definition. For example:

<assign name="runXQuery">
   <copy>
      <from expression="'Associated Press'"/>
      <to variable="publisher"/>
   </copy>
   <copy>
      <from>
      <category xmlns="http://samples.otn.com">Computing</category>
      </from>
      <to variable="category"/>
   </copy>
   <copy>
      <from expression="ora:processXQuery
         ('books.xq',bpws:getVariableData('input','payload'))"/>
      <to variable="output" part="payload"/>
   </copy>
</assign>

Using BPEL XQuery Function Parameters

The Oracle BPEL XQuery function that is introduced in the preceding example (ora:processXQuery) has two parameters:

  • view_name

  • context_node

The view_name parameter is mandatory and must be a string, which specifies the name of the stored XQuery file (also called XQS view) to be executed. The file name may optionally include the file extension .xq. If the first argument does not end with .xq, XQS appends the file extension before searching for the file.

The context_node parameter is optional. If present, its value must be an XML node. This XML node becomes the context item for the query being executed. For more details see Accessing Context Items with XQuery.

Accessing Context Items with XQuery

You can pass an XML document to an XQuery expression without binding it to an external variable. This is referred to as binding a document to the context item. Inside a query expression, a context item is accessed with a special syntax (.).

For example, if the context item is bound to a document with the root element <books> and a sequence of <book> child elements, the following expression is valid:

for $i in ./book/title return $i

Use the context_node parameter of the BPEL XQuery function to bind an XML document as an XQuery context item.


Note:

A context item can be supplied to an XQuery executed by XQS only in the Oracle BPEL environment. This functionality is not available to general J2EE applications using XQS. However, XML nodes may be passed to XQuery as regular query parameters and XQS function arguments.

Using XQS View Functionality in BPEL

XQS provides an extension to the standard XQuery language in the form of queries stored in files referred to as XQS views. An XQS view has a name and an associated XQuery expression.

The view implementation is the XQuery expression associated with the view. The following query expression can be associated with the file myView.xq:

for $i in  fn:doc("/dir/file.xml") return $i/line-item[@id=10]

Top Level Views

Top level views are invoked directly from the BPEL process. In the following example, the view named myTopView is invoked from the BPEL process using the processXQuery XPath function:

<copy>
   <from expression="ora:processXQuery('myTopView.xq'))"/>
   <to variable="output" part="payload"/>
</copy>

The following rules apply to top level views:

  • XQuery files for top level views must be placed directly in the root suitcase folder of the BPEL process, they cannot be in a sub-folder.

  • Only implicitly declared external variables (described in the following section) may be used in top level views, and the names of external variables must match BPEL process variables in active scope at the place in the process where the view is called.

  • Context item document may be used only with top level views.

As an example, myTopView may have the following contents:

for $i in fn:doc("/dir/file.xml") return $i/line-item[@id=$bpelVar]

The external variable $bpelVar is not declared and is expected to be a BPEL process variable.

Nested View

A nested view is an XQS view that is called from another XQS view. In order to fit into the XQuery language syntax, the calling view refers to the nested view as an external function. For the nested view, the view name is also the name of the external function, declared in another query expression that uses the view. In the following example, myView is the name of the nested view:

declare namespace bpel="urn:oracle.bpel.xq";
declare function bpel:myView($arg as xs:integer) as node()* external;

Whenever the external function myView() is called in a query expression, XQS binds an integer parameter of the function to an external variable inside myView() and executes the preceding query. The resulting sequence is the result of the external function call.

XQS views, which are essentially stored queries, provide a way to embed one XQuery within another XQuery, at the same time maintaining the nested query separate and modular, subject to independent changes. For example, the outer (embedding) query might look like this:

declare namespace bpel=Óurn:oracle.bpel.xqÓ;
declare function bpel:myView($arg as xs:integer) as node()* external;
for $i in bpel:myView(2301) return $i/shipping-status

An external XQS view function is associated with its query through a text file of the same name as the function and the file extension .xq. For example, a file named myView.xq would contain the following text:

declare variable $x as xs:integer external;
for $i in  fn:doc("/dir/file.xml") return $i/line-item[@id=$x]

As seen in the preceding examples, all nested views must belong to some namespace. This namespace may be either a default Oracle BPEL namespace urn:oracle.bpel.xq or a user-defined namespace. The Using BPEL Namespaces and Folders for XQS Views section explains how to group nested views into user-defined namespaces.

Using External XQuery Variables

External variables in XQuery allow the passing of input values from the environment that embeds an XQuery expression into the XQuery expression. This concept is similar to bind variables in SQL. The following example is a simple query that declares three external variables ($x, $y, and $z). The query simply returns the values of variables in a sequence.

declare variable $x as xs:string external; 
declare variable $y as xs:integer external;
declare variable $z external;
($x, $y, $z)

Declaring a type for an external variable is optional as illustrated by variable $z. It is advisable to declare an external variable with a type whenever the type is known in advance, because it causes additional static and dynamic type-checking to the query and makes the application more robust.

XQuery also allows external variables to be implicitly declared. If a variable notation ($) is used in an XQuery expression without prior declaration, the variable is assumed to be an implicitly declared external variable. The following xquery expression is equivalent to the preceding example, except that the three external variables are implicitly declared:

($x, $y, $z)


Note:

Implicitly declared external variables are available only within the BPEL environment. General J2EE applications using XQS may only use external variables that are explicitly declared in the queries.

For XQuery evaluation, all external variables must be bound to actual values. This is achieved differently for implicitly declared and explicitly declared external variables.If an external variable is implicitly declared, its name must match the name of a BPEL process variable currently in scope. The BPEL Process Manager and XQS bind the value of the process variable to the external variable of the same name.


Note:

Implicitly declared external variables are only allowed in the views called directly from the BPEL XQuery function, they are not allowed in the nested XQS Views.More examples of using BPEL process variables in XQS views are provided in the "Using BPEL Process Variables in an XQS View" section.

If an external XQuery variable is explicitly declared in the query, it's value is taken from the argument to the XQS view function according to the order in which the external variables are declared in that view. XQS views invoked from other views as XQS functions are called nested views.


Note:

Explicitly declared external variables may be used only in nested views when in the BPEL environment.

To summarize, if an XQS view is invoked directly from the BPEL XQuery function, the only external variables allowed in such a view must be implicitly declared, their values are taken from the BPEL process variables of the same name which are in scope when the XQuery function is called. For example:

Within the topLevelView.xq XQS view file, the query

for $b in $bpelVar1/a/b return $b[@id = $bpelVar2]

can be invoked at a place in a BPEL process where the variables $bpelVar1 and $bpelVar2 are in scope:

<copy>
   <from expression="ora:processXQuery('topLevel.xq')"/>
   <to variable="output" part="payload"/>
</copy>

If an XQS view is invoked from another XQS view by means of an XQS external function, the only external variables allowed in such a view must be explicitly declared. The values of the arguments of the XQS view function are taken in the order in which the arguments are passed and assigned to the external variables in the order in which the variables are declared in the view. For example, within the nestedView.xq XQS view file:

declare variable $x as element() external;
declare variable $y as xs:integer external;
for $b in $x/a/b return $b[@id = $y]

The nestedView query is invoked from another view, called topView. topView.xq contains the following:

declare namespace ns1="folder1";
declare function ns1:nestedView($arg1 as element(), $arg2 as xs:integer) external;
let $el := <x>
              <a>
                 <b id="1">b-content</b>
              </a>
           </x>return ns1:nestedView($el, 1)

Before executing nestedView, XQS binds the external variable $x to the element <x> and external variable $y to the integer 1.

Using BPEL Process Variables in an XQS View

You can use variables declared in a BPEL process within an XQS view that is called directly from the XQuery XPath function without additional declarations required within the view.Suppose a BPEL process contains the variables $bpPurchaseAmt and $state, which are assigned some values elsewhere in a BPEL process.In addition, suppose that an XQS view file (purchaseAmtAddTax.xq) has been packaged along with the BPEL process and has the following content:

declare namespace bpl = "urn:oracle.bpel.xq";
declare function bpl:stateTax($st as xs:string) as xs:decimal external;
$bpPurchaseAmt *(1+ bpl:stateTax($state))

The example also assumes that another XQS view file (stateTax.xq) is packaged with the BPEL process.Two external variables ($bpPurchaseAmt and $state) are used in the example. They are not declared in the query. For a successful evaluation, the XQS view must be called from the XQuery XPath function in a BPEL process and the process must have variables $bpPurchaseAmt and $state in scope and with values appropriate for the query to process.

Using BPEL Namespaces and Folders for XQS Views

There are two options for using namespaces and folders for XQS views within the BPEL environment:

  • Use the default namespace and folder

  • Use a custom namespace and sub-folders

Default Namespace and Folder

The default location for XQuery files is the root folder of the BPEL process suitcase. XQS associates namespaces with folders. The default XQuery folder is associated with the default Oracle BPEL namespace urn:oracle.bpel.xq. Any prefix can be used to designate this default namespace, for example dflt, bpel, myroot, and so on.All top level XQS views, that is, views invoked directly from a BPEL process, must be placed in the default folder. This means that all top-level views belong to the default namespace urn:oracle.bpel.xq. Therefore, when a view name is provided to the XQuery processXQuery function, the default namespace is not supplied.Views placed in the default folder may also be invoked as nested views by using a prefix for the default namespace. For example, assume the following folder structure:

<process suitcase root>   /view1.xq   /view2.xq

The contents of view1.xq that allows it to invoke view2.xq would be:

declare namespace dflt = "urn:oracle.bpel.xq";
declare function dflt:view2($st as xs:string) as xs:decimal;
for $i in dflt:view2("Oracle") return $i

Custom Namespaces and Sub-Folders

XQS in Oracle BPEL environment gives you an option to organize your queries into sub-folders of the default folder as well. The sub-folders can be only one level deep. For example, in the following folder structure XQS will be able to find views: view1.xq, view2.xq, view3.xq, view4.xq and view5.xq. However, XQS is not able to find invisible.xq because it is in a folder that is two levels deep from the suitcase root.

<process suitcase root>
   /view1.xq
   /view2.xq
   /subfolder1
      /view3.xq
      /view4.xq
      /subfolder12
         /invisible.xq
   /subfolder2
      /view5.xq

Views located in sub-folders may only be used as nested views. All nested views must be declared in the calling query as external functions and, thus, must belong to a namespace. The namespace of the views that are located in sub-folders is the name of the sub-folder. However, you can give one or more arbitrary prefixes to that namespace.In the example folder structure, the following declarations may be used before invoking the views in subfolder1/ and subfolder2/.

declare namespace dflt="urn:oracle.bpel.xq";
declare namespace sub1="subfolder1";
declare namespace sub2="subfolder2";
declare function dflt:view1() as external;
declare function sub1:view4() as external;
declare function sub2:view5() as external;


Note:

XQuery does not calculate relative position of one folder with respect to another. Regardless of where the calling query is located, you always refer to a nested view by the namespace derived from the name of the folder where the nested view is located.

Using the preceding example of a folder structure, view1.xq and view3.xq are invoked from view5.xq as follows:

declare namespace dflt="urn:oracle.bpel.xq";
declare namespace sub1="subfolder1";
declare function dflt:view1() as external;
declare function sub1:view3() as external;

dflt:view1()//price - sub1:view3()//discount

Using a URL as a View Name

XQS also supports invocation of a view that is accessible through a live Web URL (using the http:, ftp:, or file: protocol), in addition to a file on a local file system. If the view name is a URL, it must reflect the exact name of the file to be accessed (XQS will not append an .xq file extension), and the text file for the view must be available from that URL at the time of the invocation. For example:

<copy>
   <from expression="ora:processXQuery
      ('http://myhost/bpeldemos/views/myView.xq')"/>
   <to variable="output" part="payload"/>
</copy>


Note:

A URL may be used as a view name only in top-level views and never in nested views.

XQS Client APIs Reference

This section provides reference documentation for XQS public classes and user interfaces:

XQSFactory Reference

This section lists the methods of the oracle.xqs.client.XQSFactory class. The factory class is used to create instances of the main XQS client interfaces - XQSFacadeI and QueryParameterI. These methods are described in detail in the sections that follow, which document the particular interface returned by the factory. The oracle.xqs.client.XQSFactory class supplies the following methods:

  • XQSFacadeI getXQSFacade()

  • QueryParameterI getQueryParameter()

  • QueryParameterI getQueryParameter(String namespace, String localName)

  • QueryParameterI getQueryParameter(String localName)

XQS QueryParameterI Reference

This section documents the factory methods used to obtain the oracle.xqs.client.QueryParameterI interface and its methods. A QueryParameterI array is used for binding external variables for a query when using the XQS general-purpose Java API or the EJB API.

"Example 3: XQSFacadeI API with an XQS View" includes an example of using QueryParameterI for an input parameter.

Factory Methods Returning QueryParameterI

The oracle.xqs.client.XQSFactory class supplies the following methods that create an instance of the QueryParameterI interface :

  • getQueryParameter()

  • getQueryParameter(String namespace, String localName)

  • getQueryParameter(String localName)

When you obtain a QueryParameterI instance from the XQSFactory factory, you may specify the name of the external XQuery variable to be bound, and this must match the name from the corresponding external variable declaration in the XQuery prolog. Alternatively, you may create a QueryParameterI instance without a name and later use the setName() method of the QueryParameterI interface to set the parameter name, which also must match the name of an external variable in the XQuery prolog. XQuery variables use XML names, so the QueryParameterI constructor can take two string values—one for the namespace and one for the local name. If you do not specify a namespace, then null is assigned to the namespace in the qualified name.

QueryParameterI Methods

The QueryParameterI interface supplies the following methods, each to set a value of an external XQuery variable. These methods reflect XML types supported by XQS, and their Java equivalents; also see "Supported Types for Query Parameters". There are also methods to set and get the parameter name and to inquire if a parameter is null.

  • javax.xml.namespace.QName getName()

    Use this method to find out the name of the parameter.

  • void setName(String namespace, String localPart)

    Use this method to set the name of the parameter by providing namespace and local part of the QName.

  • boolean isNull()

    Use this method to find out if the parameter value is set to Null. A parameter is set to Null only by calling one of the set*Null() methods listed in this section. An un-initialized parameter is not considered to be set to Null.

  • void setBase64Binary(String value)

    Use this method to bind a Base64Binary value, represented by a Java string (for example, vYrfOJ39673//-BDiIIGHSPM=+), and corresponding to the XML base64Binary type.

  • void setBase64BinaryNull()

    Use this method to bind a Base64Binary external variable to Null.

  • void setBoolean(boolean value)

    Use this method to bind a boolean value, corresponding to the XML boolean type.

  • void setBooleanNull()

    Use this method to bind a boolean external variable to Null.

  • void setDateTime(java.util.GregorianCalendar value boolean isTimeZoneSet)

    Use this method to bind a GregorianCalendar value representing a particular point in time, corresponding to the XML dateTime type. Set isTimeZone to true if the calendar object TimeZone property has been set. (See http://java.sun.com/j2se/1.4.2/docs/api/ for information about using GregorianCalendar objects.)

  • void setDateTimeNull()

    Use this method to bind a dateTime external variable to Null.

  • void setDateTime(String strValue)

    Use this method to bind a String value representing a particular point in time, corresponding to the XML dateTime type.

  • void setDecimal(java.math.BigDecimal value)

    Use this method to bind a BigDecimal value, corresponding to the XML decimal type.

  • void setDecimalNull()

    Use this method to bind a decimal external variable to Null.

  • void setDouble(double value)

    Use this method to bind a double value, corresponding to the XML double type.

  • void setDoubleNull()

    Use this method to bind a double external variable to Null.

  • void setDuration(String value)

    Use this method to bind a String value representing a duration, corresponding to the XML duration type. See http://www.w3.org/TR/xmlschema-2/#duration for information about lexical (string) representations of durations.

  • void setDurationNull()

    Use this method to bind a duration external variable to Null.

  • void setDayTimeDuration(double seconds)

    Use this method to bind a double value representing a dayTime portion of duration value in seconds, corresponding to the XML dayTimeDuration type. See http://www.w3.org/TR/xmlschema-2/#dayTimeDuration for information about representations of dayTimeDuration.

  • void setDayTimeDurationNull()

    Use this method to bind a DayTimeDuration external variable to Null.

  • void setYearMonthDuration(int months)

    Use this method to bind an int value representing a yearMonth portion of duration value in months, corresponding to the XML yearMonthDuration type. See http://www.w3.org/TR/xmlschema-2/#yearMonthDuration for information about representations of yearMonthDuration.

  • void setYearMonthDurationNull()

    Use this method to bind a yearMonthDuration external variable to Null.

  • void setFloat(float value)

    Use this method to bind a floating point value, corresponding to the XML float type.

  • void setFloatNull()

    Use this method to bind a float external variable to Null.

  • void setHexBinary(String value)

    Use this method to bind a hexadecimal binary value, represented by a Java string (for example, 0FB7), and corresponding to the XML hexBinary type.

  • void setHexBinaryNull()

    Use this method to bind a hexBinary external variable to Null.

  • void setInt(int value)

    Use this method to bind an integer value, corresponding to the XML int type.

  • void setIntNull()

    Use this method to bind an int external variable to Null.

  • void setInteger(int value)

  • void setInteger(long value)

  • void setInteger(java.math.BigInteger value)

    Use one of the setInteger() methods to bind an integer value, corresponding to the XML integer type. Choose the appropriate signature based on the value representation or magnitude.

  • void setIntegerNull()

    Use this method to bind an integer external variable to Null.

  • void setLong(long value)

    Use this method to bind a long integer value, corresponding to the XML long type.

  • void setLongNull()

    Use this method to bind a long external variable to Null.

  • void setString(String value)

    Use this method to bind a Java string value, corresponding to the XML string type.

  • void setStringNull()

    Use this method to bind a string external variable to Null.

  • void setAnyURI(java.net.URI value)

    Use this method to bind a URI value, corresponding to the XML anyURI type.

  • void setAnyURINull()

    Use this method to bind an anyURI external variable to Null.

  • void setNode(org.w3c.dom.Node value)

    Use this method to bind an XML node, corresponding to the XML anyType type or to any user-defined XML type.

  • void setNodeNull()

    Use this method to bind an external variable of anyType or any user-defined XML type to Null.


Note:

The QueryParameterI class has no getter methods corresponding to these setter methods.

XQSFacadeI Reference

This section documents the factory methods that are used to obtain the oracle.xqs.client.XQSFacadeI interface and its methods. The interface is a general-purpose Java client API that XQS supplies. See "Using the Java Interface Client API" for usage instructions and an example.

Factory Method Returning XQSFacadeI

The oracle.xqs.client.XQSFactory class supplies the following method that creates an instance of the XQSFacadeI interface:

  • getXQSFacade()

XQSFacadeI Methods

The XQSFacadeI interface supplies the following methods:

  • void execute(String xquery, QueryParameterI[] params)

    Use this method to execute an ad-hoc query. Pass in a string containing the query, and a QueryParameterI array for any bind parameters. (See "XQS QueryParameterI Reference".) The array can be null if there are no parameters to pass.

  • void executeView(String viewName, String namespace, QueryParameterI[] params)

    Use this method to execute an XQS view directly. Pass in a view name by specifying the local name and namespace (as strings), and pass in a QueryParameterI array for any bind parameters (or null). The view name and namespace together define a qualified name and must match the corresponding function name and namespace in your configuration, according to the <function-name> subelement of <xqsview-source>, and its namespace or prefix attribute.

  • oracle.xml.xqxp.datamodel.XMLItem getNextItem()

    After using execute() or executeView(), use getNextItem() to obtain the next item in the result sequence, as an Oracle XMLItem instance. The first getNextItem() call returns the first item in the sequence. If you call this method after you have already retrieved the last item, it returns null.


    Important:

    A call to the getNextItem() method triggers the evaluation of the item by XQuery. Any resources required when executing the query (such as a database connection or file handle) are not freed until after the last getNextItem() call.

  • java.util.ListIterator getErrors()

    If you configure any of the XQS functions used in your query to continue even if errors are encountered (as discussed in "Configuring XQS Function Error Handling"), you can use getErrors() to retrieve information about any errors that may have been encountered during execution of XQS functions. This method returns an iterator over a collection of XQSErrorI objects, from which you can retrieve the specifics of each error. (See "XQSErrorI Reference".) If there were no errors, the iterator will point to an empty collection.

  • void close()

    Use this to free all resources associated with the query. It is good practice to call close() after retrieving all query results.

XQS EJB Client API Reference

This section documents EJB client methods supported by XQS, through the XQSClientRemote and XQSClientHome interfaces for remote EJBs, and the XQSClientLocal and XQSClientLocalHome interfaces for local EJBs. There are versions of these interfaces for either stateful or stateless session beans.

See "Using the EJB Client API" for usage instructions and examples.

Stateful EJB Client Methods

The following Oracle-specific methods are available through EJB interfaces in the package oracle.xqs.client.ejb.stateful, for stateful session beans, and have the same functionality as the methods of the same name discussed in "XQSFacadeI Reference":

  • void execute(String xquery, QueryParameterI[] params) throws EJBException

  • void executeView(String viewName, String namespace, QueryParameterI[] params) throws EJBException

  • oracle.xml.xqxp.datamodel.XMLItem getNextItem() throws EJBException

  • java.util.ListIterator getErrors()

  • void close()

Stateless EJB Client Methods

The following Oracle-specific methods are available through EJB interfaces in the package oracle.xqs.client.ejb.stateless, for stateless session beans:

  • java.util.Vector execute(String xquery, QueryParameterI[] params) throws EJBException

    Use this method to execute an ad-hoc query. Pass in a string containing the query, and a QueryParameterI array for any bind parameters. (See "XQS QueryParameterI Reference".) The array can be null if there are no parameters to pass. Results are fully materialized, returned in a Vector instance.

  • java.util.Vector executeView(String viewName, String namespace, QueryParameterI[] params) throws EJBException

    Use this method to execute an XQS view. Pass in a view name by specifying the local name and namespace (as strings), and pass in a QueryParameterI array for any bind parameters (or null). The view name and namespace together define a qualified name and must match the corresponding function name and namespace in your configuration, according to the <function-name> subelement of <xqsview-source>, and its namespace or prefix attribute. Results are fully materialized, returned in a Vector instance.

  • java.util.ListIterator getErrors()

    This method has the same functionality as the method of the same name discussed in "XQSFacadeI Reference".

XQS JSP Tag Library Reference

XQS supplies custom JSP tags for either stateful or stateless access to XQuery.

See "Using the JSP Tag Library" for usage instructions and examples.

See the Oracle Containers for J2EE Support for JavaServer Pages Developer's Guide for general information about using JSP tag libraries.


Notes:

The prefix "xq:" is used in the tag syntax here. This is by convention but is not required. You can specify any desired prefix in your taglib directive.

For tag syntax, note the following:

  • Italic indicates where you specify a value or string.

  • Optional attributes are enclosed in square brackets: [...]

  • Default values of optional attributes are indicated in bold.

  • Choices in attribute values are separated by vertical bars: |

  • Except where noted, you can use JSP runtime expressions to set tag attribute values: "<%= jspExpression %>"


JSP Tags for Stateful Access

Use these tags when you want a stateful access to XQuery.

XQS executeCursor Tag

Use this tag to prepare and execute the query. It has the following syntax. (The param subtag, used for any bind parameters, is described next.)

<xq:executeCursor
  [ xqueryString = "query" ]
  [ xqsViewName = "viewname" ]
  [ namespace = "namespace" ]
    cursorId = "cursorname"
  [ maxItems = "maxnumber" ]
  [ toWriter = "true" | "false" ]
    toXMLDoc = "docname"
    resultItems = "arrayname"
    errors = "errorvarname" > 

   <xq:param ... />
   <xq:param ... />
   ...

</xq:executeCursor>

Important:

  • For query input, you must use either the xqueryString attribute or the xqsViewName and namespace attributes.

  • You must provide variable names for the output attributes toXMLDoc, resultItems, and errors.


Use attributes of the executeCursor tag as follows:

  • xqueryString: When using an ad-hoc query, use this attribute to specify the complete XQuery syntax of the query. It is usually easiest to define the query in a string variable and specify the name of the variable in a JSP expression:

    String myquerystring = "...";
    ...
    <xq:executeCursor ... xqueryString = "<%=myquerystring%>" ... >
       ...
    </xq:executeCursor>
    
    
  • xqsViewName: When using an XQS view, use this attribute to specify the view. Specifically, this is the name of the corresponding XQS function name in your configuration.

  • namespace: If you use xqsViewName to specify a view, you must also use namespace to specify the namespace of the XQS function for the view, according to your XQS configuration.

  • cursorId (required): Use this tag to specify the name of a variable for the cursor, for later use. (The variable will be declared by the JSP container.) You will reference the specified variable name when you use a next tag to retrieve results from the cursor, and when you use the close tag to close the cursor. Here is an example:

    <xq:executeCursor ... cursorId="mycursor" ... >
       ...
    </xq:executeCursor>
    ...
    <xq:next cursorId="mycursor" />
    ...
    <xq:close cursorId="mycursor" />
    
    
  • maxItems: Use this if you want to specify a maximum number of items to receive from the query, such as maxItems="10000". Items beyond that point will be discarded, and the next tag will stop returning values after maxItem items have been received.

  • toWriter: Set this to "true" to output query results to the JSP output stream. The writing occurs every time the next tag is executed.

  • toXMLDoc (required): Provide the name for a variable to be used by a related next tag to output query results to an XML DOM document. The document can be used after the executeCursor tag. A variable of type org.w3c.dom.Document will be declared by the JSP container. Here is an example:

    <xq:executeCursor cursorId="mycursor" toXMLDoc="mydoc" ... >
       ...
    </xq:executeCursor>
    
    <xq:next cursorId="mycursor" />
    
    Element root = mydoc.getDocumentElement();
    ...
    
    

    After using the executeCursor tag, each time you execute the next tag you will receive a batch of result nodes collected in the document mydoc.


    Important:

    • The toXMLDoc document collects only results that are XML nodes. Results that are primitive types are ignored for the XML document, but collected through the resultItems array.

    • The toXMLDoc document holds only the batch of items from one execution of the next tag. Each subsequent execution of next overwrites the items with a new set of items.

    • You cannot use a runtime expression for the toXMLDoc attribute.



    Note:

    The specified name will also become the name of the root element of the document.

  • resultItems (required): Provide the name for a variable to be used by a related next tag to output query results to an array list. A variable of type java.util.ArrayList will be declared by the JSP container. The ArrayList instance can be used after the executeCursor tag. Here is an example:

    <xq:executeCursor ... resultItems="myobjects" ... >
       ...
    </xq:executeCursor>
    
    Node node = (Node)myobjects.get(0);
    ...
    
    

    After using the executeCursor tag, each time you execute the next tag you can access a result item from the myobjects variable.


    Important:

    • The resultItems variable holds only the batch of items from one execution of the next tag. Each subsequent execution of next overwrites the items with a new set of items.

    • You cannot use a runtime expression for the resultItems attribute.


  • errors (required): Provide the name of a variable to be used in retrieving errors that result from execution of the XQS query. A variable of type java.util.ListIterator will be declared by the JSP container for an iterator over a collection of XQSErrorI objects (one object for each error). The iterator can be used after the executeCursor tag. Here is an example:

    <xq:executeCursor cursorId="mycursor" errors="myerroriter" ... >
       ...
    </xq:executeCursor>
    <xq:next cursorId="mycursor" />
    
    XQSErrorI error = (XQSErrorI)myerroriterator.next();
    ...
    
    

    See "XQSErrorI Reference" for how to use XQSErrorI objects.


    Important:

    You cannot use a runtime expression for the errors attribute.

XQS param Tag

Use this subtag of executeCursor and execute to specify any external bind parameters for the query (one param tag for each parameter). It has the following syntax:

<xq:param
    localName = "localvarname"
  [ namespace = "namespace" ]
    value = "bindvalue"
    type = "bindparamtype" 
/>

Use attributes of the param tag as follows:

  • localName (required): Use this to specify the local part of the external variable name.

  • namespace: Use this to specify the namespace part of the external variable name. Because it is permissible to use a local variable name without a namespace, this attribute is optional.

  • value (required): Use this for the value to be bound, which will presumably be a runtime value using a JSP runtime expression:

    <xq:param ... value = "<%=jspExpression%>"... />
    

    Note:

    The type of the bind value must be a match for the type attribute setting, as noted in Table 8-3.

  • type (required): Use this to specify the data type of the bind parameter, indicating an XML type for which the XQS QueryParameterI interface supports a corresponding Java type. Supported settings, and the type or types for which they are appropriate, are shown in Table 8-3. (Also see "Supported Types for Query Parameters".)

Table 8-3 Correspondence of Java Types to type Attribute Settings

type Attribute Setting Matching Java Type(s)

boolean

java.lang.Boolean

string

java.lang.String

int

java.lang.Integer

integer

java.lang.Integer, java.lang.Long, java.math.BigInteger

long

java.lang.Long

float

java.lang.Float

double

java.lang.Double

decimal

java.math.BigDecimal

base64Binary

java.lang.String

(Representation of the value.)

hexBinary

java.lang.String

(Representation of the value.)

anyURI

java.net.URI

dateTime

java.util.GregorianCalendar

(With the assumption that the time zone for the calendar value has been initialized appropriately.)

duration

java.lang.String

(Lexical representation of the duration, discussed at http://www.w3.org/TR/xmlschema-2/#duration.)

node

java.lang.String

(Text representation of the node, to be parsed by an XML parser.)


XQS next Tag

Use this tag to process results, item by item or batch by batch, from the executeCursor tag, referencing the cursor ID name that you specified in that tag. The next tag has the following syntax:

<xq:next
    cursorId = "cursorname"
  [ batchSize= "numitems" ]
  [ itemsFetched = "intvarname" ]
/>

Use attributes of the next tag as follows:

  • cursorId (required): Use this attribute to reference the cursor name for the query, as specified in the executeCursor tag. The cursor must still be open (there has not yet been a close tag specifying the same cursor name).

  • batchSize: Use this attribute if you want XQS to use batch mode for the query. Specify an integer value for how many items you want fetched from the cursor each time the next tag is executed. The default value is "1" (no batching).

  • itemsFetched: Specify the name of a java.lang.Integer variable for a value that indicates how many items were fetched from the cursor in the current next tag execution. The variable will be declared by the JSP container.

Here is an example:

...
<xq:executeCursor cursorId="mycursor"
                  resultItems="myresults"
                  toXMLDoc="mydoc"
                  errors="myerrors" ... >
   <xq:param ... />
   ...
</xq:executeCursor>
<% 
  int items;
  do {
  // Populate output vehicles (myresults array and mydoc document)
%>
   <xq:next
                cursorId="mycursor"
                itemsFetched="fetched" />
<%
  items = fetched.intValue();
  } while(items>0)
  // ... Here is where you would retrieve results from the output vehicles ...
%>
...

XQS close Tag

For a stateful JSP (using the executeCursor tag), use the close tag to free resources associated with the query. It has the following syntax:

<xq:close
    cursorId = "cursorname"
/>

Use attributes of the close tag as follows:

  • cursorId (required): Use this attribute to reference the cursor name, as specified in the executeCursor tag, corresponding to the query you want to close.

JSP Tag for Stateless Access

Use the execute tag when you want a stateless access to XQuery.

XQS execute Tag

Use this tag to prepare and execute the query. It has the following syntax:

<xq:execute
  [ xqueryString = "query" ]
  [ xqsViewName = "viewname" ]
  [ namespace = "namespace" ]
  [ maxItems = "maxnumber" ]
  [ toWriter = "true" | "false" ]
    toXMLDoc = "docname"
    resultItems = "arrayname"
    errors = "errorvarname" > 

   <xq:param ... />
   <xq:param ... />
   ...

</xq:execute>

Important:

  • For query input, you must use either the xqueryString attribute, or the xqsViewName and namespace attributes.

  • You must provide variable names for output vehicles using the required attributes toXMLDoc, resultItems, and errors.


Aside from cursorId, this tag uses the same attributes as the executeCursor tag (for stateful access). It also uses the XQS param subtag, as does executeCursor, for bind parameters. See "XQS executeCursor Tag" and "XQS param Tag".

XQSErrorI Reference

This section provides reference documentation for the interface oracle.xqs.client.XQSErrorI.

If you configure any of the XQS functions used in your query to continue even if errors are encountered, as discussed in "Configuring XQS Function Error Handling", you can retrieve information about any errors that may have occurred during execution of the XQS function for the query. Errors are returned in an iterator of XQSErrorI objects.

The XQSErrorI interface provides a number of methods to return its key information—the name of the XQS function that encountered the error, the type of error (an XQS-specific designation), the error message, and the error code (if applicable)—in various formats. See "Obtaining Information from XQS Error Objects" for usage instructions and an example.

  • String getFunctionQName()

    Use this method to get the fully qualified name of the XQS function that encountered the error, as follows:

    {namespace_URI}/local_name
    
    
  • int getErrorType()

    Use this method to get an integer constant that indicates the XQS error type designation:

    • XQSERR_MISSING_SRC if the data source cannot be found—such as if an HTTP 404 error is returned, the file is not found for a document source, the source is down, or the desired table in a database source does not exist.

    • XQSERR_SRC_ACCESS if the data source is found but returns an access error. This would include, for example, an ORA-xxxxx error from an Oracle database, a Web site login error, or a parser error when reading a document source.

    • XQSERR_SRC_ERROR if the data source is found but returns some kind of error besides an access error, such as a business method error, a Web service fault message, or a SQL error for a database source.

    • XQSERR_PARAM if XQS encountered problems in passing bind parameters to the data source or receiving output parameters from the data source. For example, this is returned if XQS could not convert an input string to the corresponding data type required according to the WSDL document, or if XQS could not transform a non-XML file into an XML document with the particular transformer it is using.

    • XQSERR_SRC_CONFIG if XQS encountered a problem while processing configuration of the XQS function.

    • XQSERR_INTERNAL if XQS encountered an unexpected internal error.

  • String getErrorMessage()

    Use this method to retrieve the error message, either from the data source or from XQS, as applicable. This method never returns null. If a data source generates an error without returning a message, XQS returns the generic message "Function generated an error."

  • String getErrorCode()

    For an error generated by a data source, use this method to return the XQS error code string.

  • String toString()

    Use this method to combine the function name, error type, error code, and error message into a single string.

  • String toXMLString()

    Use this method to combine the function name, error type, error code, and error message into a string representation of an XML error element.

  • public static String[] typenames

    This static array contains the following string representations of XQS error types :

    • XQSERR_MISSING_SRC

    • XQSERR_SRC_ACCESS

    • XQSERR_PARAM

    • XQSERR_SRC_ERROR

    • XQSERR_SRC_CONFIG

    • XQSERR_INTERNAL

    Given a Java object error of type XQSErrorI, the expression XQSErrorI.typNames[error.getErrorType()] returns a string appropriate for the error type of the object.

  • org.w3c.dom.Node toXMLNode()

    Use this method to retrieve the function name, error type, error code, and error message in DOM node format.

XQS Configuration File Reference

This section has an alphabetical dictionary of elements of the XQS configuration file, xqs-config.xml. You can find the XML schema for this XQS configuration file at http://www.oracle.com/technology/tech/xml/xqs/xqs-config.xsd. The file is also available with the XLSDemo application in xds/samples/XQSDemo/XDS/xqs-config.xsd. Also see "How to Configure Your XQS Functions" for information about the use of key elements for each category of data sources.

XQS looks for xqs-config.xml in the xqs-resources.jar file at the top level of the application EAR file. For each external function declared for an XQuery expression, XQS looks for configuration for the function in the xqs-config.xml file.

A summary of the hierarchy of elements in the XQS configuration file follows. For each XQS function you configure, you will use a <document-source>, <wsdl-source>, or <xqsview-source> element, depending on the kind of data source the function needs to access.

<bind-prefix>

Parent element: <xqs-config>

Child elements: <use-prefix>

Required? Optional; zero or one

Use this element, with <use-prefix> subelements, if you want to designate prefixes to represent certain XML namespaces in XQS configuration elements. Each <use-prefix> subelement designates one prefix.

The <bind-prefix> element has no attributes.

<cache-properties>

Parent element: <document-source>, <wsdl-source>, or <xqsview-source>

Child elements: <in-memory>

Required? Optional; zero or one inside each occurrence of a parent element

If you enable XQS caching through the isCached attribute of <document-source>, <wsdl-source>, or <xqsview-source>, use the <cache-properties> element with its required <in-memory> subelement to set caching properties for use by the particular XQS function. See "XQS Caching Strategies" for related considerations.

The <cache-properties> element is ignored if isCached="false" (the default).

Table 8-4 <cache-properties> Attribute

Name Description

time-to-live

Values: Integer (seconds)

Default: n/a (required)

This specifies how long items are held in the cache before expiring.


<dataSource>

Parent element: <xqsview-source>

Child elements: None

Required? Optional; zero or one inside each occurrence of the parent element

Use the value of this element to specify the JNDI name of the data source as defined in data-sources.xml configuration file. The data source specified is used by XQS to connect to the database, such as in the following example:

<dataSource>jdbc/OracleCoreDS</dataSource>

The <dataSource> element has no attributes.

<document-source>

Parent element: <xqs-sources>

Child elements: <cache-properties>, <documentURL>, <error-message>, <function-name>, <output-element>, <XMLTranslate>

Required? Optional; zero or more

Use a <document-source> element and its subelements (as appropriate) for each XQS function you configure that uses a document source.

You can configure the use of a generic document source where the URL is taken at runtime, or you can use the <documentURL> subelement to specify a fixed URL in the configuration. (For an example of taking a URL at runtime, see "Configuring an XQS Function that Accesses a Document Source".)

For a non-XML document, you can use the <XMLTranslate> element to configure translation to XML, if the document conforms to formats supported by the D3L tool. (See "Preparing to Use a Non-XML Document Source" for information about D3L.)

Table 8-5 <document-source> Attributes

Name Description

isCached

Values: Boolean

Default: false

Set this to "true" to cache results from the data source. Also see "Configuring XQS Caching" and information about the <cache-properties> element.

largeData

Values: Boolean

Default: false

Set this to "true" if you want to provide a hint to XQS that it should try to use memory-saving internal optimizations to handle large volumes of data. (Use only when necessary.) Also see "Configuring XQS Document Sources for Large Data".

onError

Values: dynamicError | emptySequence | errorMessage

Default: dynamicError

This determines which error-handling mode XQS uses. See "Configuring XQS Function Error Handling".


<documentURL>

Parent element: <document-source>

Child elements: None

Required? Optional; zero or one inside each occurrence of the parent element

Use the value of this element to specify the document to use as the data source, such as in the following example:

<documentURL>http://host:port/xqsdemos/Repository/pos-2KB.xml</documentURL>

If it is a non-XML document, use the <XMLTranslate> subelement of <document-source> to specify the translation tool for XQS to use.

The <documentURL> element has no attributes.


Notes:

  • If you are behind a firewall and the specified URL requires external Internet access, be aware that you must also configure OC4J with appropriate proxy settings.

  • As an alternative to predefining a document URL through the <documentURL> element, you can omit this element and declare the XQuery external function (corresponding to the XQS function you are configuring) to take the document URL as a runtime argument.

  • For your specification of the document URL, be aware that if the document is on the local file system, using file:// protocol instead of http:// protocol will give you faster data retrieval.


<error-message>

Parent element: <document-source>, <wsdl-source>, or <xqsview-source>

Child elements: None

Required? Optional; zero or one inside each occurrence of a parent element

For the XQS errorMessage error mode—determined by the onError attribute of <document-source>, <wsdl-source>, or <xqsview-source>—use the <error-message> element if you want to predefine a fixed error message instead of forwarding whatever message comes from the data source. The element value constitutes the message, as in the following example:

<error-message>No information available</error-message>

Also see "Introduction to XQS Error Handling".

The <error-message> element has no attributes.

<function-name>

Parent element: <document-source>, <wsdl-source>, or <xqsview-source>

Child elements: None

Required? Required inside each occurrence of a parent element; one only

Use this element to declare the desired name of the XQuery function that XQS will implement to access the data source. The element value is the function name, and attribute settings specify the function namespace. (Each XQuery function must belong to some namespace.) Be aware that you must reference the function namespace every time you invoke the function in an XQuery expression, unless you have declared that particular namespace as the default for the XQuery expression.

Use the namespace attribute to specify the namespace directly; use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. You must use one or the other, but do not use both namespace and prefix at the same time. For information about using the <output-element> element, see "Considerations for Using <output-element >" on .

The function name you specify here is the function name you will declare in the XQuery external function declarations in your code, to access the corresponding data source.

Here is an example:

<function-name  namespace="http://xmlns.oracle.com/ias/xqs">
   customerInfo
</function-name>

Or, alternatively, if xqs has been defined as a prefix for the XQS namespace:

<function-name prefix="xqs">customerInfo</function-name>

Here is an example of an XQuery function declaration corresponding to the preceding configuration:

declare namespace xqs="http://xmlns.oracle.com/ias/xqs";
declare function xqs:customerInfo() external;

Table 8-6 <function-name> Attributes

Name Description

namespace

Values: URI

Default: None (required if prefix not used)

Specifies the namespace directly.

prefix

Values: String

Default: None (required if namespace not used)

Specifies the namespace through a predefined prefix.


<in-memory>

Parent element: <cache-properties>

Child elements: None

Required? Required if the parent element is used; one only

Use the <cache-properties> element and its <in-memory> subelement to set XQS cache properties. Attributes of the <in-memory> element determine the caching mode. For simple memory-based caching, set useSpool and useDiskCache both to "false". For memory-based caching with the capability of spooling cached data to disk as necessary, in case of any memory shortage, set useSpool to "true" and useDiskCache to "false". For disk-based caching, set useDiskCache to "true" and useSpool to "false". With disk-based caching, cached data will survive a server failure. See "XQS Caching Strategies" for related considerations.

For example, for memory-based caching that uses spooling if necessary:

<cache-properties time-to-live="600">
   <in-memory useSpool="true" useDiskCache="false"/>
</cache-properties>

See "Configuring XQS Caching" for additional information.

Table 8-7 <in-memory> Attributes

Name Description

useSpool

Values: Boolean

Default: false

Set useSpool="true" for memory-based caching of data, but with spooling enabled. This allows cached data to be spooled from memory to disk so that it is not lost if cached objects have to be removed from memory to reclaim space.

useDiskCache

Values: Boolean

Default: false

Set useDiskCache="true" for disk-based caching of data, which allows the cached data to be recovered in the event of a server failure.


<input-parameters>

Parent element: <wsdl-source> or <xqsview-source>

Child elements: <part>

Required? Required inside each occurrence of a parent element; one only

Use this element to specify input parameters to the XQS function for the associated data source. Use a <part> subelement for each parameter. Type-matching, for WSDL sources only, is according to the type-match attribute.

This element is required even if there are no input parameters; use an empty element in that case.

Table 8-8 <input-parameter> Attribute

Name Description

type-match

Values: strict | none

Default: strict

For a WSDL source, this determines whether XQS performs type-matching for input parameters. With a setting of type-match="strict" (the default), XQS compares the input type you specify (through the <schema-type> subelement of <part>) to the type of the corresponding part in the WSDL document. "Strict" matching, the only level currently supported, requires an exact match of the type names. If the actual input type is not among the types supported by the <schema-type> element, choose the closest supported type and use a setting of type-match="none". (Equivalently, you can avoid type-matching if you do not use a <schema-type> element.)


<itemType>

Parent element: <xquery-sequence>

Child elements: None

Required? Optional; zero or one inside each occurrence of the parent element

When you use the <xquery-sequence> element to specify a sequence type as an input type for an XQS view, where each member of the sequence is of the same type, you can use the <itemType> subelement to specify the type of the members. This is useful in allowing XQS to perform type-checking.

Use the namespace attribute to directly specify a namespace that defines the type; use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. You must use one or the other, but do not use both namespace and prefix at the same time.

Table 8-9 <itemType> Attributes

Name Description

namespace

Values: URI

Default: None (required if prefix not used)

Specifies the namespace directly.

prefix

Values: String

Default: None (required if namespace not used)

Specifies the namespace through a predefined prefix.

location

Values: URI

Default: None

For a user-defined type, you can specify a URI with the location where the schema that defines the type can be found. This is useful for type-checking by XQS, if a corresponding detailed declaration of the parameter exists in your XQuery prolog.


<mapping>

Parent element: <typeMap>

Child elements: <xmlType>

Required? Required inside the parent element if that is used; one or more

For a WSDL source with Java or EJB binding, use this in conjunction with its <xmlType> subelement to map between a Java type and an XML type. Use the typeClass attribute to specify the Java type.

Table 8-10 <mapping> Attribute

Name Description

typeClass

Values: String

Default: n/a (required)

This attribute specifies a fully qualified Java class name for XML-Java type mapping. The class must be in the OC4J class path.


<operation>

Parent element: <wsdl-source>

Child elements: None

Required? Required inside each occurrence of the parent element; one only

Use this to specify the Web service operation to execute. It would be an operation defined in the WSDL document that the <wsdlURL> element points to, with the value of the XQS <operation> element corresponding to the name attribute of an <operation> element in the WSDL. Here is an example:

<operation>getCustomerByKey</operation>

The <operation> element has no attributes.

<output-element>

Parent element: <document-source>, <wsdl-source>, or <xqsview-source>

Child elements: None

Required? Optional; zero or one inside each occurrence of a parent element

The value of this element defines the item type of the sequence that is the result of the XQS function. This element is not required, but XQS can use the information for type-checking and optimizations. We especially advise you to use this element for an XQS view source with the setting WSDLvisibility="true". XQS would still generate a valid Web service operation without the type information, but it is not a good practice to define an untyped Web service in a production system.

You can define the result item in either of two ways: by its type or by a reference to an element previously defined in another schema. The name of such an imported element is given as the text value of the element <output-element>. For example, if items in the result sequence will be <po> elements from the schema urn:PurchaseOrders namespace, <output-element> might look like this:

<output-element namespace="urn:purchaseOrders" >po</output-element>

If items in the result sequence will be elements of type POType defined in the schema urn:PurchaseOrders namespace, found at http://myHost:/mySchemas/PurchaseOrders.xsd, <output-element> might look like this:

<output-element prefix="po_ns" 
   location="http://myHost:/mySchemas/PurchaseOrders.xsd" 
   type="POType"/> 

Use the namespace attribute to specify the namespace directly; or use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. You must use one or the other, but do not use both namespace and prefix at the same time.

Here is an example for a complex type:

<output-element namespace="http://xmlns.oracle.com/ias/xqs/CustomerDemo"
   location="http://host:port/xqsdemos/Customers.xsd" 
   type="CustomersType">
   customers
</output-element>

Here is an example for a simple type:

<output-element prefix="xs">float</output-element>

Table 8-11 <output-element> Attributes

Name Description

namespace

Values: URI

Default: None (required if prefix not used)

Specifies a namespace directly.

prefix

Values: String

Default: None (required if namespace not used)

Specifies a namespace through a predefined prefix.

location

Values: URI

Default: None

Specify a URI with the location where the schema that defines the element or type can be found. This attribute is required when you use the <output-element> element in an <xqsview-source> element that has WSDLvisibility="true". Otherwise it is not required, but is useful for type-checking by XQS if a corresponding detailed declaration of the parameter exists in your XQuery prolog.

type

Values: String

Default: None

Specify a local name for the XML type that will be the item type of the sequence that is the result of the XQS function. The namespace for the type name is determined from the namespace or prefix attribute. The type attribute is not required if the type of result item is defined through a reference to am element name given as the text value of the <output-element> element.


<part>

Parent element: <input-parameters>

Child elements: <schema-type>, <xquery-sequence>

Required? Required unless parent element is empty; one for each input argument

Use a <part> element for each input parameter for a WSDL source or XQS view. Specify the name and position (order) of the parameter through the attributes. Use a <schema-type> subelement or an <xquery-sequence> subelement (for XQS views only) to specify the type, as appropriate. Specifying a type is not required, but is useful so that XQS can perform type-checking.

For a WSDL source, each <part> element must correspond to a part in the input message of the WSDL operation that is used to access the source. For an XQS view, each <part> element must correspond to an external variable of the XQuery that defines the view, or to a bind variable in the SQL query that defines the view.

Table 8-12 <part> Attributes

Name Description

name

Values: String

Default: n/a (required)

This specifies the name of the input parameter. For a WSDL source, the name must be the same as in the WSDL document. For an XQS view, it must be the same as the name of the external XQuery variable or a SQL bind variable.

position

Values: Positive integer

Default: n/a (required)

The position attributes for all the <part> elements within an <input-parameters> element together determine the order in which the input parameters are assigned to message parts (for a WSDL source) or assigned to external or bind variables (for an XQS view). The parameter with the lowest position setting, starting with position="1", is taken first, and so on. Each <part> element must have a unique position setting.


<port>

Parent element: <wsdl-source>

Child elements: None

Required? Required inside each occurrence of the parent element; one only

The value of this element specifies the name of a Web service port defined in the WSDL document that the <wsdlURL> element points to, corresponding to the name attribute of a <port> element in the WSDL.

Attribute settings specify the namespace, but you are not required to specify a namespace if the applicable service has only one port.

Use the namespace attribute to specify the namespace directly; use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. Do not use both namespace and prefix at the same time.

For example:

<port namespace="http://customer.myeis.com/">CustomerInfo</port>

Alternatively:

<bind-prefix>
   <use-prefix prefix="myeis">http://customer.myeis.com/</use-prefix>
</bind-prefix>
...
<port prefix="myeis">CustomerInfo</port>

Table 8-13 <port> Attributes

Name Description

namespace

Values: URI

Default: None

Specifies the namespace directly.

prefix

Values: String

Default: None

Specifies the namespace through a predefined prefix.


<portType>

Parent element: <wsdl-source>

Child elements: None

Required? May be required; zero or one inside each occurrence of the parent element

The value of this element specifies the name of a Web service port type defined in the WSDL document that the <wsdlURL> element points to, corresponding to the name attribute of a <portType> element in the WSDL. This element is required if the port used for the operation has multiple bindings in the WSDL.

Attribute settings specify the namespace, but you are not required to specify a namespace if all port types in the WSDL belong to the same namespace.

Use the namespace attribute to specify the namespace directly; use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. Do not use both namespace and prefix at the same time.

For example:

<portType namespace="http://customer.myeis.com/">CustomerInfoType</portType>

Table 8-14 <portType> Attributes

Name Description

namespace

Values: URI

Default: None

Specifies the namespace directly.

prefix

Values: String

Default: None

Specifies the namespace through a predefined prefix.


<queryName>

Parent element: <xqsview-source>

Child elements: None

Required? Optional; zero or one inside each occurrence of the parent element

The value of this element specifies the name of the XQuery expression text file (.xq or.sql file) where the XQS view is defined, such as in the following example:

<queryName>UserByOrderNum.xq</queryName>

You can leave off the .xq or .sql file name extension, as XQS assumes that automatically. The directory where XQS looks for the file is according to the <repository> subelement of <xqsview-source> (or else according to a default location).

If you do not use the <queryName> element, XQS assumes the XQS view file to have the same name as the function you specify in the <function-name> subelement of <xqsview-source> with either .xq or .sql extension, depending on the type of the view.

The <queryName> element has no attributes.

<repository>

Parent element: <xqsview-source>

Child elements: None

Required? Optional; zero or one inside each occurrence of the parent element

The value of this element is the absolute path to the directory containing the XQuery expression text file (.xq file) or the SQL query file (.sql file) where the XQS view is defined. Specify the file name in the <queryName> subelement of <xqsview-source>.

If you do not use the <repository> element, XQS looks in the directory you specified through the OC4JPackager -repository option. Here is an example explicitly specifying what would be the default directory for the XQS demo application:

<repository>/META-INF/xqs/mydir/</repository>

The <repository> element has no attributes.

<schema-file>

Parent element: <XMLTranslate>

Child elements: None

Required? Required if the parent element is used; one only

If a document source is non-XML and conforms to formats supported by the D3L tool, use the <XMLTranslate> element and <schema-file> subelement to give information to XQS about how to translate the document to XML for you. (See "Preparing to Use a Non-XML Document Source" for information about D3L.)

The <XMLTranslate> element specifies the translation tool to use (D3L), and the <schema-file> element specifies the schema file to use in translation.

Here is an example:

<documentURL>http://host:port/xqsdemos/paymentInfo.csv</documentURL>
<XMLTranslate method="D3L">
   <schema-file>http://host:port/xqsdemos/paymentInfoD3L.xml</schema-file>
</XMLTranslate>

The <schema-file> element has no attributes.

<schema-type>

Parent element: <part>

Child elements: None

Required? See description; one only

For each input parameter for an XQS view, either this element or the <xquery-sequence> element (for an input sequence) is required to specify the parameter type.

For each input parameter for a WSDL source, this element is optional inside the <part> parent element, but is useful for type-checking, or for organizational purposes—to have all your types listed in the XQS configuration file. (A WSDL source cannot have an input sequence.)

Note that to perform type-checking for WSDL sources, the <input-parameters> element must have the attribute setting type-match="strict".

For <schema-type>, the element value specifies the type, and attribute settings specify the namespace. Use the namespace attribute to specify the namespace directly; use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. You must use one or the other, but do not use both namespace and prefix at the same time.

Here is an example:

<input-parameters>
  <part position="1" name="empname">
    <schema-type namespace="http://www.w3.org/2001/XMLSchema">string</schema-type>
  </part>
</input-parameters>

Or, alternatively, defining xs as a prefix for the XMLSchema namespace:

<bind-prefix>
   <use-prefix prefix="xs">http://www.w3.org/2001/XMLSchema</use-prefix>
</bind-prefix>
...
<input-parameters>
  <part position="1" name="empname">
    <schema-type prefix="xs">string</schema-type>
  </part>
</input-parameters>

Or, for a user-defined type:

<input-parameters>
   <part position="1" name="DBServiceSelect_cust_id_inparameters">
      <schema-type namespace=
         "http://xmlns.oracle.com/pcbpel/adapter/db/top/TestDBAdapter">
         DBServiceSelect_cust_id
      </schema-type>
   </part>
</input-parameters>

In addition to any user-defined XML types, XQS currently supports the following subset of types defined in the XQuery 1.0 and XPath 2.0 data model: xs:boolean, xs:string, xs:int, xs:long, xs:float, xs:double, xs:decimal, xs:base64Binary, xs:hexBinary, xs:anyURI, xs:dateTime, xs:duration, and xs:anyType. (Also see "Supported Types for Query Parameters".) If you have an XQuery/XPath input type that is not among these supported types, choose a supported type with the Java representation that best suits your data, and use a setting of type-match="none" in the <input-parameters> element. (For a WSDL source with a Java or EJB binding, this is a situation where you would also use the <typeMap> subelement of <wsdl-source>.)

Table 8-15 <schema-type> Attributes

Name Description

namespace

Values: URI

Default: None (required if prefix not used)

Specifies the namespace directly.

prefix

Values: String

Default: None (required if namespace not used)

Specifies the namespace through a predefined prefix.


<service>

Parent element: <wsdl-source>

Child elements: None

Required? May be required; zero or one inside each occurrence of the parent element

The value of this element specifies the name of a service. It would be a service defined in the WSDL document that the <wsdlURL> element points to, with the value of the XQS <service> element corresponding to the name attribute of a <service> element in the WSDL. The XQS <service> element is required if the WSDL document defines multiple services.

Attribute settings specify the namespace, but you are not required to specify a namespace if all service elements in the WSDL belong to the same namespace.

Use the namespace attribute to specify the namespace directly; use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. Do not use both namespace and prefix at the same time.

For example:

<service namespace="http://customer.myeis.com/">CustomerInfoMYEISService</service>

Table 8-16 <service> Attributes

Name Description

namespace

Values: URI

Default: None

Specifies the namespace directly.

prefix

Values: String

Default: None

Specifies the namespace through a predefined prefix.


<typeMap>

Parent element: <wsdl-source>

Child elements: <mapping>

Required? Optional; zero or one within each occurrence of the parent element

For a WSDL source with a Java or EJB binding, you can use this element as necessary to map XML types to Java types. Specify the Java type through the <mapping> subelement, and the XML type through the <xmlType> subelement of <mapping>.

The <typeMap> element has no attributes.

<use-prefix>

Parent element: <bind-prefix>

Child elements: None

Required? Required if the parent element is used; one or more

Use a <bind-prefix> element and <use-prefix> subelements if you want to designate prefixes to represent certain XML namespaces. Each <use-prefix> subelement designates one prefix, with the element value specifying a namespace and the prefix attribute specifying the prefix to represent that namespace. Here is an example:

<bind-prefix>
   <use-prefix prefix="xs">http://www.w3.org/2001/XMLSchema</use-prefix>
   <use-prefix prefix="xqs">http://xmlns.oracle.com/ias/xqs</use-prefix>
   <use-prefix prefix="myeis">http://customer.myeis.com/</use-prefix>
</bind-prefix>

Given these settings, XQS configuration elements that must specify a namespace can use, for example, prefix="myeis" instead of namespace="http://customer.myeis.com/".


Note:

A <use-prefix> designation is valid only in the XQS configuration file in which it appears, not in XQuery expressions.

Table 8-17 <use-prefix> Attribute

Name Description

prefix

Values: String

Default: n/a (required)

This attribute specifies the desired prefix.


<username>

Parent element: <document-source>

Child elements: None

Required? Optional; zero or one

This element is reserved for future security enhancements.

The <username> element has no attributes.

<wsdl-source>

Parent element: <xqs-sources>

Child elements: <cache-properties>, <error-message>, <function-name>, <input-parameters>, <operation>, <output-element>, <port>, <portType>, <service>, <typeMap>, <wsdlURL>

Required? Optional; zero or more

Use a <wsdl-source> element and its subelements (as appropriate) for each XQS function you configure that will access a WSDL-based source. (See "Supported Categories of Data Sources" for an overview of the kinds of WSDL-based sources you can use with XQS.)

Table 8-18 <wsdl-source> Attributes

Name Description

isCached

Values: Boolean

Default: false

Set this to "true" to cache results from the data source. Also see "Configuring XQS Caching" and information about the <cache-properties> element.

largeData

Values: Boolean

Default: false

Set this to "true" if you want to provide a hint to XQS that it should try to use memory-saving internal optimizations to handle large volumes of data. (Use only when necessary.) Also see "Configuring XQS Document Sources for Large Data".

onError

Values: dynamicError | emptySequence | errorMessage

Default: dynamicError

This determines which error-handling mode XQS uses. See "Introduction to XQS Error Handling".


<wsdlURL>

Parent element: <wsdl-source>

Child elements: None

Required? Required inside each occurrence of the parent element; one only

Use this to point to the WSDL document that defines the operation to be executed. The WSDL will be accessed at runtime. Here is an example:

<wsdlURL>http://api.mySearch.com/mySearch.wsdl</wsdlURL>

The <wsdlURL> element has no attributes.


Note:

If you are behind a firewall and the specified URL requires external Internet access, be aware that you must also configure OC4J with appropriate proxy settings.

<xqs-config>

Parent element: n/a (root)

Child elements: <bind-prefix>, <xqs-sources>

Required? Required; one only

This is the root element of xqs-config.xml. At a minimum, you must have this element, its <xqs-sources> subelement, and at least one subelement of <xqs-sources><document-source>, <wsdl-source>, or <xqsview-source>.

Table 8-19 <xqs-config> Attribute

Name Description

version

Values: XML name token (NMTOKEN)

Default: 1.0 (current version)

This attribute notes the version number of the xqs-config.xml schema definition. For the current XQS implementation, use the default value.


<xqs-sources>

Parent element: <xqs-config>

Child elements: <document-source>, <wsdl-source>, <xqsview-source>

Required? Required; one only

This is the parent element for the source elements for all XQS functions being configured. It does not have any attributes.

<xqsview-source>

Parent element: <xqs-sources>

Child elements: <cache-properties>, <error-message>, <function-name>, <input-parameters>, <output-element>, <queryName>, <repository>, <dataSource>

Required? Optional; zero or more

Use an <xqsview-source> element and its subelements (as appropriate) for each XQS function you configure that uses an XQS view.

Table 8-20 <xqsview-source> Attributes

Name Description

fetchSize

Values: Integer

Default: 1

This attribute takes effect only for SQL-based XQS views which connect to a relational database. The attribute is optional.The fetchSize attribute is translated into a call to the setFetchSize method of java.sql.PreparedStatement. The attribute serves as a hint to JDBC to define the number of rows in the result set that will be fetched from the database in one round trip. Note that the setFetchSize parameter in JDBC (and, therefore, the fetchSize attribute in XQS) is only a hint; it is not binding.

isCached

Values: Boolean

Default: false

Set this to "true" to cache results from the data source. Also see "Configuring XQS Caching" and information about the <cache-properties> element.

largeData

Values: Boolean

Default: false

Set this to "true" if you want to provide a hint to XQS that it should try to use memory-saving internal optimizations to handle large volumes of data. (Use only when necessary.) Also see "Configuring XQS Document Sources for Large Data".

onError

Values: dynamicError | emptySequence | errorMessage

Default: dynamicError

This determines which error-handling mode XQS uses. See "Introduction to XQS Error Handling".

WSDLvisibility

Values: Boolean

Default: false

Set this to "true" if you want XQS to expose the view as a Web service operation in the Web service component of your application. This attribute cannot be applied to SQL-based XQS views. Also see "Using an XQS View Exposed as a Web Service Operation".

SQLResultType

Values: relational | XMLType

Default: relational

This attribute is only applicable when using SQL-based views. The attribute sets whether a database query returns data in the relational (tabular) form or as XML. When using the Oracle XML database, you can use the SQL-based XQS view to select XML type values from the database (without subsequent conversion) by setting the SQLResultType attribute to XMLType. Also see "Configuring an XQS Function that Uses an XQS View".

rowTag

Values: String

Default: ROW

This attribute is only applicable when using SQL-based views. When specified, it overrides the default name for elements used in the relational-to-XML conversion of the database result. The attribute is applicable only if the SQLResultType attribute is set to relational.

Also see "Configuring an XQS Function that Uses an XQS View".

rowIdAttr

Values: String

Default: null

This attribute is only applicable when using SQL-based views. When specified, it controls the numbering of row elements in the result. The attribute is applicable only if the SQLResultType attribute is set to relational.

The value of rowIdAttr attribute is the name of the numbering attribute in the result row element. Rows will be numbered starting from 1, as 1, 2, 3, … The setting of "" is equivalent to the default behavior and suppresses the row numbering attribute.

The rowTag and rowIdAttr attributes may be used independently from each other. That is, you can specify only one of the attributes and use the default for the other.

Also see "Configuring an XQS Function that Uses an XQS View".

XMLFormat

Values: XSU

Default: XSU

This attribute is only applicable when using SQL-based views. The attribute has only one value, XSU. An additional value will be enabled in a future release to support the Web Rowset result format. The limitation in the current release is caused by dependency on JDK 1.5 functionality.


<XMLTranslate>

Parent element: <document-source>

Child elements: <schema-file>

Required? Optional; zero or one inside each occurrence of the parent element

If a document source is non-XML and conforms to formats supported by the D3L tool, use the <XMLTranslate> element and <schema-file> subelement to give information to XQS about how to translate the document to XML for you. This is useful for translating formatted files, such as Excel comma-separated-values (CSV) files, to XML. See "Preparing to Use a Non-XML Document Source" for information about D3L.

The method attribute of <XMLTranslate> specifies the translation tool to use. XQS currently supports the D3L translation tool.

The <schema-file> subelement is required, to specify the schema to use in translation.

Table 8-21 <XMLTranslate> Attribute

Name Description

method

Values: D3L

Default: n/a (required)

Specifies the translation tool for XQS to use. XQS currently supports D3L.


<xmlType>

Parent element: <mapping>

Child elements: None

Required? Required inside each occurrence of the parent element; one only

For a WSDL source with Java or EJB binding, use this in conjunction with its <mapping> parent element to map between a Java type and an XML type. Use attribute settings to specify the namespace of the XML type: use the namespace attribute to specify the namespace directly; use the prefix attribute as a shortcut if you have previously defined a namespace prefix through a <bind-prefix> element. You must use one or the other, but do not use both namespace and prefix at the same time.

The <mapping> parent element specifies the Java type.

Here is an example:

<typeMap>
   <mapping typeClass="org.w3c.dom.Node">
      <xmlType prefix="myeis">Customer</xmlType>
   </mapping>
   ...
</typeMap>

Table 8-22 <xmlType> Attributes

Name Description

namespace

Values: URI

Default: None (required if prefix not used)

Specifies the namespace directly.

prefix

Values: String

Default: None (required if namespace not used)

Specifies the namespace through a predefined prefix.


<xquery-sequence>

Parent element: <part>

Child elements: <itemType>

Required? This or <schema-type> is required inside each occurrence of the parent element or an XQS view; one only

For each input parameter for an XQS view, where the parameter is an XQuery/XPath sequence type, you must use this element (as opposed to the <schema-type> element for a non-sequence type) inside the <part> parent element to specify the type.

For a WSDL source, input sequences are not supported so this element is not relevant.

The <xquery-sequence> element can be used for a heterogeneous sequence consisting of items of multiple types, in which case it should be an empty element. Alternatively, it can include the <itemType> subelement to specify the common type of each member of a homogeneous sequence.

The <xquery-sequence> element has no attributes.

OC4JPackager Reference

This section provides reference documentation for parameters and properties of the XQS packager utility, OC4JPackager. For an overview, see "Introduction to OC4JPackager". For usage instructions, see "How to Use OC4JPackager to Package Your XQS Application".


Note:

For specifying paths in parameter or property settings, OC4JPackager supports paths that are either relative to the current directory (including the use of "." and ".." directory notation) or absolute.

OC4JPackager Parameters

This section documents OC4JPackager parameters in alphabetical order, with descriptions and usage examples. Run OC4JPackager as follows (where % is the command prompt):

% java -jar OC4JPackager.jar -option1 value1 -option2 value2 ... -optionN valueN

appArchives

Required. Specify a directory path.

Use this to specify where your application is located—either the directory containing an EAR file, or the top-level directory of an EAR structure.

-appArchives /dir1/myappdir

help

Optional. This is a toggle flag.

Use this without any other parameters to show OC4JPackager usage information and a parameter list.

-help

jsp

Optional (required if you use the XQS JSP tag library). This is a toggle flag.

Use this to include the XQS JSP tag library JAR file (xquerytaglib.jar) in the output EAR file.

-jsp

name

Required. Specify an EAR file name.

Use this to specify the desired name of the output EAR file (with or without the .ear extension). Its location will be determined by the -output parameter.

-name myxqsapp.ear

no_ws

Optional. This is a toggle flag.

Use this to prevent the generation of Web services.

-no_ws

output

Required. Specify a directory path.

Use this to specify where OC4JPackager should place the EAR file that it creates. The file name is according to the -name parameter.

-output /dir1/mydeployments

repository

Optional. Specify a directory path.

Use this to specify your XQS repository location, where your XQS views are stored.

-repository ORACLE_HOME/xds/samples/repository

sf

Optional (required if you use the XQS stateful EJB client API). This is a toggle flag.

Use this to include the XQS stateful EJB client JAR file (xqsclient-stateful.jar) in the output EAR file.

-sf

This also results in the following <module> element being added to the application.xml file:

<module>
   <ejb>xqsclient-stateful.jar</ejb>
</module>

sl

Optional (required if you use the XQS stateless EJB client API). This is a toggle flag.

Use this to include the XQS stateless EJB client JAR file (xqsclient-stateless.jar) in the output EAR file.

-sl

This also results in the following <module> element being added to the application.xml file:

<module>
   <ejb>xqsclient-stateless.jar</ejb>
</module>

xqsConfigFile

Required. Specify a file path.

Use this to specify the path (including file name) of the XQS configuration file, xqs-config.xml, for your application.

-xqsConfigFile /dir1/subdir/myconfigdir/xqs-config.xml

Java Properties for OC4JPackager

This section documents Java properties supported by OC4JPackager, in alphabetical order, with descriptions and usage examples. Use the Java -D option, as follows:

java -Dproperty1=value1 -Dproperty2=value2 -jar OC4JPackager.jar \
     -option1 value1 -option2 value2 ... -optionN valueN

oracle.home

Optional. Specify a directory path.

OC4JPackager supports the oracle.home property to specify your Oracle home directory. For example:

-Doracle.home=/myroot/myoraclehome

Specifying an Oracle home directory allows XQS to find any client JAR files requested through the -jsp, -sf, and -sl flags and bundle them with your application. If you do not set oracle.home, these flags are ignored.

java.home

Required. Specify a directory path.

Specify the path to your Java home directory, from which OC4JPackager will run the java command for its work (such as unbundling and bundling JAR files).

-Djava.home=/dir1/myjavahome

OC4JPackager will exit if you do not specify this property.

java.util.logging.properties.file

Optional. Specify a file path.

Use this to indicate a path to the file, including the file name, where you specify Java logging properties, as in the following example (where myfile.properties is in the current directory):

-Djava.util.logging.properties.file=myfile.properties

Without specifying a logging properties file, you will not see any Java error output.

OC4JPackager logs messages using the standard J2SE logging framework, as described at the following location:

http://java.sun.com/j2se/1.4.2/docs/guide/util/logging/

Within the properties file, OC4JPackager supports the property oracle.xds.tools.OC4JPackager.level to specify any of the following logging levels for messages from the packager: SEVERE, WARNING, INFO, or FINE. For high-level progress messages use INFO; for low-level debugging messages, use FINE.

Here are sample entries for a logging properties file, to send messages to the console and use the INFO level for messages from OC4JPackager:

#  output to console
handlers= java.util.logging.ConsoleHandler
...
# set packager level to INFO  
oracle.xds.tools.OC4JPackager.level=INFO

xds.packager.work.dir

Optional. Specify a directory path.

Use this to specify a working directory that OC4JPackager can use when it unbundles and rebuilds EAR files.

-Dxds.packager.work.dir=/some/dir

The default location is your user.home directory.

XQS Troubleshooting

This section describes how to enable OC4J logging and offers an assortment of troubleshooting tips for your XQS application.

Enabling OC4J Logging

You can enable OC4J logging by using the Java property java.util.logging.properties.file to specify a logging properties file. In this file you can specify Java logging settings, including the OC4JPackager logging level. Logging properties are defined by standard J2SE logging, as specified at the following location:

http://java.sun.com/j2se/1.4.2/docs/guide/util/logging/

For more information about logging, see "java.util.logging.properties.file" , the chapter on logging in OC4J in the Oracle Containers for J2EE Configuration and Administration Guide, and the logging implementation guidelines in the Oracle Containers for J2EE Developer's Guide.

Key XQS Symptoms, Causes, and Remedies

This section discusses possible problems you may encounter with your XQS application, and their solutions.


Note:

There are no Dynamic Monitoring Service (DMS) metrics for the XQS implementation.

Trouble with large volumes of data: If you have trouble loading large XML documents into memory, enabling the largeData flag may allow you to proceed. See "Configuring XQS Document Sources for Large Data".

XQS function did not load properly: You may see an error message such as the following (where "arity" refers to the number of arguments the function takes, and "ns" and "funcname" are replaced by the namespace and name of your function):

XP0017: It is a static error if the expanded QName and number of arguments in a function call do not match the name and arity of an in-scope function in the static context. Detail: unknown function 'ns:funcname'

The key point is that XQuery did not recognize the function, which is an indication that the function could not be loaded properly by XQS, perhaps because it was not configured correctly. Examine your OC4J error log file (such as ORACLE_HOME/j2ee/home/log/oc4j/log.xml) and look for a detailed explanation of the particular problem with this function.

External function has inconsistent signatures: Consider an error such as the following:

external function "Foo" has inconsistent signatures: the one defined in function
library framework is different from the one declared in function declaration
prolog

Be aware that the term "function library framework" in the context of XQS refers to the signature defined within an <input-parameters> element in the XQS configuration file. You must ensure that <part> definitions under the <input-parameters> element match function signatures in your XQuery prologs.

If you have trouble bringing your XQuery signatures into consistency with your configuration, you may be trying to use an unsupported XML type. (See "Supported Types for Query Parameters".) As a workaround, however, you can avoid prolog type declarations for XQuery parameters or XQuery return values altogether. For example, instead of a fully typed function declaration such as the following:

declare function xqs:Foo ($s as element()) as xs:positiveInteger external;

You can declare the function without types, as follows:

declare function xqs:Foo ($s) external;

However, you are always required to specify the number of input parameters, through your XQS configuration.

XQS Sample

For an XQS sample, go to the Oracle Technology Network at the following Web site and search for "XQS":

http://www.oracle.com/technology/tech/java/oc4j/1013/how_to/index.html