我正在用Java编写库,它使用OSB提供的oracle库来执行XQuery
XQuery之一包含:
<cfgEndDate>{ fn-bea:date-from-dateTime($endDate) }</cfgEndDate>
XQuery在OSB环境中正常工作,甚至在Eclipse OEPE
中也能正常工作尽管如此,尝试使用Java执行XQuery(我从OSB分配中获取xquery.jar
)导致异常:
oracle.xquery.XQException: XPST0081: It is a static error if a QName used in an
expression contains a namespace prefix that cannot be expanded into a namespace URI by
using the statically known namespaces.
Detail: Undeclared namespace prefix 'fn-bea'
at oracle.xquery.PreparedXQuery.<init>(PreparedXQuery.java:202)
at oracle.xquery.PreparedXQuery.<init>(PreparedXQuery.java:128)
at oracle.xquery.XQueryContext.prepareXQuery(XQueryContext.java:424)
更新1:
我刚尝试使用net.sf.saxon.query
库做同样的事情。它也无法管理这个功能:
XPST0081 XQuery static error near #...>{ fn-bea:date-from-dateTime($#:
Prefix fn-bea has not been declared
net.sf.saxon.trans.XPathException: One or more static errors were reported during
query analysis
at net.sf.saxon.query.QueryParser.parseQuery(QueryParser.java:344)
at net.sf.saxon.query.QueryParser.makeXQueryExpression(QueryParser.java:140)
at net.sf.saxon.query.StaticQueryContext.compileQuery(StaticQueryContext.java:536)
更新2
我发现fn-bea:date-from-dateTime()
函数位于weblogic中:
com.bea.core.xquery_1.3.0.0.jar
package weblogic.xml.query.runtime.datetime.ext
class DateFromDateTime
但我发现没有任何可能将它与已知的XQuery引擎一起使用,而且,我们希望使用所有fn-bea
函数,而不仅仅是这个函数。
有谁知道如何解决这个问题或建议支持fn-bea
的Java XQ引擎。
答案 0 :(得分:0)
尝试使用Oracle XQuery Processor for Java(XQJ API)。它支持XQuery 3.0功能
http://orafmwsoa.blogspot.com/2014/06/running-xquery-from-java-applications.html
http://docs.oracle.com/cd/E16655_01/appdev.121/e17604/adx_j_xqj.htm