java使用xquery_我想在java中使用XQuery For Xml处理

好吧,有另一种方法来获取所需的 JARS ,你不需要为此安装oracle数据库 . 我在这个链接中找到了解决方案,

但是你不需要经历整个链接,需要注意的是,所有必要的 JARS 都可以从Oracle XQuery for Hadoop实现获得 .

这是链接,

只需下载 Oracle XQuery for Hadoop 4.1.0 并使用路径中的库提取并创建一个普通的Java Project .

我从你的链接尝试了这个例子,它可以工作

import javax.xml.xquery.XQConnection;

import javax.xml.xquery.XQException;

import javax.xml.xquery.XQPreparedExpression;

import javax.xml.xquery.XQSequence;

import oracle.xml.xquery.OXQDataSource;

public class HelloWorld {

public static void main(String[] args) throws XQException {

OXQDataSource ds = new OXQDataSource();

XQConnection con = ds.getConnection();

String query = "{1 + 1}";

XQPreparedExpression expr = con.prepareExpression(query);

XQSequence result = expr.executeQuery();

System.out.println(result.getSequenceAsString(null));

result.close();

expr.close();

con.close();

}

}

在路径中跟随 JARS ,

apache-xmlbeans orai18n-mapping oxquery xmlparserv2_sans_jaxp_services xqjapi

还有另一个建议,

我安装了Oracle Express Edition 11.2 OracleXE112_Win64 并且它没有所需的 JARS ,XE可能具有有限的功能,所以尝试安装不同的一个 .

此处此链接Embedding XQuery in Java建议使用SAXON XSLT和XQuery处理器 . SAXON

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java使用xQuery可以通过以下步骤实现: 1. 引入xQuery解析器:Java可以使用Saxon或XMLStarlet来解析xQuery语句,需要在项目引入相关的jar包。 2. 创建xQuery查询语句:使用xQuery语言编写需要执行的查询语句。 3. 创建XML文档:将需要查询的XML数据存储在一个XML文件。 4. 解析XML文档:使用Java的DOM或SAX解析器解析XML文档。 5. 执行xQuery查询:将查询语句传递给xQuery解析器,并执行查询操作。 6. 处理查询结果:解析器返回查询结果,Java程序可以将结果存储在内存或输出到文件等。 以下是一个使用Saxon解析器执行xQuery查询的Java示例代码: ```java import net.sf.saxon.s9api.*; public class XQueryExample { public static void main(String[] args) throws SaxonApiException { // 创建xQuery查询语句 String xquery = "for $x in doc('example.xml')//book where $x/price>30 return $x/title"; // 创建Processor和XQueryCompiler对象 Processor processor = new Processor(false); XQueryCompiler compiler = processor.newXQueryCompiler(); // 编译查询语句 XQueryExecutable exec = compiler.compile(xquery); // 创建XQueryEvaluator对象 XQueryEvaluator query = exec.load(); // 解析XML文档 DocumentBuilder builder = processor.newDocumentBuilder(); XdmNode doc = builder.build(new File("example.xml")); // 设置查询上下文 query.setContextItem(doc); // 执行查询并处理结果 XdmValue result = query.evaluate(); for (XdmItem item : result) { System.out.println(item.getStringValue()); } } } ``` 以上代码使用Saxon解析器执行了一个xQuery查询,查询了一个XML文档价格大于30的书籍的标题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值