Release Notes
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
BEA Liquid Data for WebLogic 8.5 provides on-demand access to, and aggregation of, information in relational databases, Web services, Java function, XML files, and other types of disparate data. During development, Liquid Data is accessed as an application running under WebLogic Workshop. This is where data services, including query functions, are developed.
Once developed, application developers — using access technologies such as the Liquid Data mediator API, JDBC, SQL, or Liquid Data controls — can invoke Liquid Data query functions as a means of providing their applications with access to integrated, updatable data from their enterprise.
These Release Notes are subject to revision and are available at:
http://download.oracle.com/docs/cd/E13190_01/liquiddata/docs85/relnotes/index.html
Items modified or added are so marked by date.
This document includes the following topics:
This section describes limitations in the current BEA Liquid Data for WebLogic 8.5 release and includes workarounds, where applicable.
The table below lists a CR (Change Request) number for each problem. Refer to this track number as limitations are addressed.
Please contact BEA customer support at http://support.bea.com for assistance in tracking unresolved problems.
Table 1 Known Product Limitations and Workarounds
Java functions return elements as untyped. [added: June 30, 2005] |
|
An untyped XML stream is returned by the runtime Java function processor instead of returning a typed XML stream. |
|
For Java functions that return an XMLBean object, add a wrapper read function in the physical data service file that validates the returned Java object by associating it with a type. Specifically, the user can make the imported external function private and then create a public read method that wraps the results of the external call with a validate(). Modify the physical data service function to be private by changing the kind attribute from read to private: |
|
1. Create a wrapper function that validates the physical data service function with kind="read" so that it is exposed to the other data service. For example:
|
|
ROWTYPE input cursor not currently supported when turning a stored procedure into a data service. |
|
Stored procedure IN and INOUT cursors containing ROWIDs are not currently supported for metadata import. |
|
Avoid importing metadata on stored procedures which required use of IN or INOUT ROWID parameters. |
|
The query engine cannot retrieve data from a Sybase data source when generated SQL contains functions which have dependencies on Java services. |
|
When using Sybase as a datasource, some SQL functions such as LTRIM and RTRIM work correctly in the database only when Java services are enabled by running the following in the SA role. |
|
Enable Java services while in the SA role. Refer to Sybase documentation for further details. |
|
A cached data source being accessed using an async() function fails with an internal error. |
|
Asynchronous access to a cached data source using the |
|
Async access and caching are two tactics to improve latency of slow data sources. However, you should avoid using them together for the same source. |
|
The XQuery 1.0 processing-instruction() node test is not fully supported in the BEA XQuery processor. |
|
Using |
|
WSDLs with multiple services may not work correctly with Liquid Data. |
|
Split multiple services in the WSDL into multiple WSDL files. |
|
Erroneous results when using fn:matches() with a regular expression containing a caret (^). |
|
The match beginning-of-line operator (^) in regular expressions produces erroneous results when used with |
|
Identifiers within two characters of the maximum length allowed by the database result in an error. |
|
Some databases place limits on the length of identifiers (30 in the case of Sybase). Liquid Data places single quotes around pushdown queries, effectively reducing the maximum identifier length by two characters (28 in the case of Sybase). |
|
All platforms running Sybase (and possibly other) databases. |
|
Possible options include renaming the table or creating a view with a shorter name. |
|
Some data sources may not appear when attempting to import metadata. |
|
The functionality to manage JDBC data sources and connection pools during metadata import is limited to the same level of functionality provided by via BEA Workshop (Tools |
|
For full functionality use the WebLogic Administration Console to manage JDBC data sources and connection pools. |
|
This version of Liquid Data cannot invoke SOAP 1.2 based Web services. |
|
Linux application built in Workshop may fail with the message "Error creating temporary file". |
|
While building an application inside Workshop on Linux, you may get the above error when 1) the application includes a large number of schema files, and 2) when the Platform Installation is under a different user's name than the user running Workshop. |
|
Ensure that the Workshop instance is running under the same name as was used for Platform installation. |
|
Access control policies associated with a data service function may disappear if the function's number of parameters is changed. |
|
A data service function's signature is it's QName and the number of parameters (arity) of the function. If you set security policies on a function and changes the number of parameters to the function, then this function is treated as a new function and the previously set policies will no longer be in effect. |
|
If a functions arity is changed, the user will have to reapply security policies to that function. |
|
BEA DB2 JDBC XA driver returns the error XAER_RMERR when a local transaction read is followed by a global transaction read. |
|
Pertains to a known JDBC driver problem described in BEA CR229071. |
|
Liquid Data Web service generation may fail to compile if the original was created in Workshop. |
|
If you have a data service created from a Workshop-originated Web service and then, subsequently, you turn your data service into a web service via a Liquid Data control, the project build will fail due to a duplicate schema element error. |
|
Assume that you have a Workshop-generated Web service named getCustomerOrderByCustomerID. A WSDL for this Web service with default targetnamespace would create the following schema elements:
When you import this wsdl, the same schema elements will be in the imported schema file and will be associated with the data service read function. When you build a Liquid Data control for this data service read function and generate a Web service from that control, a Web service function is created:
When compiling this Web service file, now workshop generates two identical schema elements each for {http://www.openuri.org/}getCustomerOrderByCustomerID and {http://www.openuri.org/}getCustomerOrderByCustomerIDResponse. Thus create the schema element clash. If user had modified either the target namespace of this final JWS or changed the function name to a different one like this: org.openuri.GetCustomerOrderByCustomerIDResponseDocument getCustomerOrderByCustomerIDNEW(org.openuri.GetCustomerOrderByCustomerIDDocument p0) Then the types generated will be as follows and there will be no clash. {http://www.openuri.org/}getCustomerOrderByCustomerID and {http://www.openuri.org/}getCustomerOrderByCustomerIDResponse {http://www.openuri.org/}getCustomerOrderByCustomerIDNEW and {http://www.openuri.org/}getCustomerOrderByCustomerIDNEWResponse Thus the schema clash will be avoided. When compiling this WebService file, now workshop generates two identical schema elements each for {http://www.openuri.org/}getCustomerOrderByCustomerID and {http://www.openuri.org/}getCustomerOrderByCustomerIDResponse. Thus create the schema element clash. If user had modified either the target namespace of this final JWS or changed the function name to a different one like this: org.openuri.GetCustomerOrderByCustomerIDResponseDocument getCustomerOrderByCustomerIDNEW(org.openuri.GetCustomerOrderByCustomerIDDocument p0) Then the types generated will be as follows and there will be no clash. {http://www.openuri.org/}getCustomerOrderByCustomerID and {http://www.openuri.org/}getCustomerOrderByCustomerIDResponse {http://www.openuri.org/}getCustomerOrderByCustomerIDNEW and {http://www.openuri.org/}getCustomerOrderByCustomerIDNEWResponse |
|
When compiling this Web service file, Workshop now generates two identical schema elements each for:
Thus the schema elements clash. If you modify either the target namespace of the final JWS or change the function name to a different one such as:
Then the types generated will be as follows and there will be no clash. |
|
|
|
An invalid data service file is generated if the data service file is associated with a schema global element that is in a different namespace than the schema file ( |
|
If you have two schema files, one importing another, resulting in having an imported schema global element that is in a different namespace than the importing schema file's namespace, then the generated data service file will be invalid if the imported schema global element is the target element of the data service. For example, say you have schema |
|
The statement in the problem description (above) can be corrected by changing the import file's namespace to point to the urn:schema:s2 namespace instead of urn:schema:s1 namespace. Alternatively, you can select E2 by associating that element from the In the general case associate the data service file with the schema file that contains the element instead of selecting schema file that has the import statement. |
|
BEA Informix JDBC driver does not return nullability information. |
|
The BEA Informix driver does not return information about table column nullability (that is, it is marked as unknown). Thus during metadata import the minOccurs of the elements corresponding to the columns in the generated XML schemas is set to 0. |
|
Modify the imported metadata files by changing the minoccurs value for the nullable columns from 0 to 1. |
|
There are two limitations with this MSSQL VARIANT data type (sql_variant): |
|
During metadata import, tables with multibyte names may create multibyte namespace prefixes based on the table name's first few characters. The resulting data service file will not be parsed correctly because the XMLBeans parser is unable to handle multibyte namespace prefix value. |
|
In the Source View syntax highlighting may become off by a character if certain sequences appear in the query. |
|
Liquid Data IDE Test View limitation when performing a SDO update. |
|
Through Liquid Data Test View Data you can accomplish typical read and update actions. For example, you can create new SDO records as part of update steps. However, when adding a new SDO record that has a nested structure, the template generated will only have first-level (i.e., no nested) elements. |
|
You can add subsequent nested SDO records by right-mouse clicking on the container node. |
|
During metadata import the BEA Sybase JDBC driver is not showing all tables to which user has authorized access. |
|
During metadata import the BEA Sybase JDBC driver may not show all tables which have been granted access to the user. |
|
All platforms accessing Sybase through the BEA Sybase JDBC driver. |
|
This is a BEA Sybase driver limitation. For the import purpose, you can change to |
|
Repeated builds of a Workshop application containing one or more Web service projects can run out of memory. |
|
If you have a Workshop application that has a large number of Web service files ( |
|
Obtain and apply the Workshop patch associated with CR226814. This patch corrects the memory leak problem described above. |
|
When using BEA Oracle JDBC driver with a TIMESTAMP values stored procedures gets truncated. |
|
When using the BEA's Oracle JDBC driver, if a stored procedure returns a TIMESTAMP value then the value gets truncated at the milliseconds level. For example, if the value was 1997-01-31 09:26:50.124 then the stored procedure will return a 1997-01-31 09:26:50.0 value. |
|
All platforms running Oracle with the BEA Oracle JDBC driver. |
|
Use the Oracle JDBC driver stored procedures that returning TIMESTAMP values. |
|
The Liquid Data cache configuration does not work if using Sybase JDBC driver because the configuration implementation uses a getBlob() call on the JDBC driver. The Sybase JDBC driver does not support getBlob(). |
|
Use the BEA JDBC driver for Sybase databases when utilizing Sybase as the Liquid Data cache data source. |
|
SQL Server JDBC driver incorrectly renders the tinyint maximum value. |
|
The SQL Server tinyint maximum value of 255 gets interpreted as -1 by the Microsoft SQL Server JDBC driver. |
|
All platforms running SQL Server with the SQL Server JDBC driver. |
|
The Informix JDBC driver does not support standard JDBC syntax for specifying TIMESTAMP values. |
|
The Informix native driver doesn't support standard JDBC syntax for specifying TIMESTAMP values. For example: 1979-03-01 00:00:00.0 is not supported. |
|
All platforms running Informix with the Informix JDBC driver. |
|
The BEA JDBC driver for Oracle does not support UROWID column type for data retrieval. |
|
When using BEA JDBC driver for Oracle, retrieving UROWID returns an error, identified by the following message:
|
|
Use the Oracle JDBC driver if your data contains UROWID column type. |
|
The Oracle stored procedure returning PL/SQL RECORD, BOOLEAN, or table with non-scalar element types is not supported. |
|
Oracle stored procedure limitations are detailed in the following currently-available document: http://www.stanford.edu/dept/itss/docs/oracle/9i/java.920/a96654/ref.htm#1007714 |
|
Metadata for SQL Server stored procedures returning CURSOR output cannot be created. |
|
When importing metadata from SQL Server, stored procedures that return CURSOR output are not supported. |
|
Modify the imported data service file to the identify the correct data type for the cursor. |
|
Metadata for DB2 stored procedures returning CLOB data cannot be created. |
|
When importing metadata from DB2, stored procedures returning CLOB data are not supported. |
|
Oracle stored procedures containing CHAR or NCHAR as input can cause a server error. |
|
If you have Oracle stored procedures that use an INOUT parameter, you may get an error when you run a stored procedure using Liquid Data. The error appears as:
|
|
Modify your stored procedure call by reducing the size of the INOUT parameter using TRIM. See Listing 1, below. |
Listing 1 Sample code related to CR202962
CREATE OR REPLACE PROCEDURE WIRELESS.SP_CHAR
(P_CHAR_IN IN CHAR,
P_CHAR_OUT OUT CHAR,
P_CHAR_INOUT IN OUT CHAR,
P_ID_OUT OUT VARCHAR2 )
IS
TEMP VARCHAR2(10);
BEGIN
SELECT C_ID INTO P_ID_OUT
FROM WIRELESS.ALL_DATATYPES
WHERE C_CHAR = P_CHAR_IN;
SELECT C_CHAR INTO P_CHAR_OUT
FROM WIRELESS.ALL_DATATYPES
WHERE C_ID = '2';
SELECT C_ID INTO TEMP
FROM WIRELESS.ALL_DATATYPES
WHERE C_CHAR = P_CHAR_INOUT;
SELECT 'WORK' INTO P_CHAR_INOUT
FROM WIRELESS.ALL_DATATYPES
WHERE C_ID = TEMP;
END;
/
to adjust the size of PCHAR_INOUT
using TRIM
(see highlighted code)
CREATE OR REPLACE PROCEDURE WIRELESS.SP_CHAR
(P_CHAR_IN IN CHAR,
P_CHAR_OUT OUT CHAR,
P_CHAR_INOUT IN OUT CHAR,
P_ID_OUT OUT VARCHAR2 )
IS
TEMP VARCHAR2(10);
ACHAR CHAR(500);
BEGIN
ACHAR := trim(P_CHAR_INOUT);
SELECT C_ID INTO P_ID_OUT
FROM WIRELESS.ALL_DATATYPES
WHERE C_CHAR = P_CHAR_IN;
SELECT C_CHAR INTO P_CHAR_OUT
FROM WIRELESS.ALL_DATATYPES
WHERE C_ID = '2';
SELECT C_ID INTO TEMP
FROM WIRELESS.ALL_DATATYPES
WHERE C_CHAR = ACHAR; // used to fail here
SELECT 'WORK' INTO P_CHAR_INOUT
FROM WIRELESS.ALL_DATATYPES
WHERE C_ID = TEMP;
END;
/
Documentation for this product is available on an Online Documentation CD-ROM that ships with the product, and is also available on the Web at the BEA e-docs documentation site at the following location:
http://download.oracle.com/docs/cd/E13190_01/liquiddata/docs85/index.html
To access the Liquid Data documentation Home page in a Web browser:
Alternatively, from within a HTML document, click the View as PDF link on the top navigation bar to open a PDF version of the currently displayed document.
Information about BEA products including Liquid Data can be found at:
http:dev2dev.bea.com
Documentation for all BEA products in both PDF and HTML format can be found at:
http://www.oracle.com/technology/documentation/index.html
If you do not have Adobe Acrobat Reader, you can get it from the Adobe Web site at http://www.adobe.com.
![]() |
![]() |
![]() |