Java代码的SPARQL解析器

时间:2013-01-24 11:44:58

标签: java sparql

有没有简单的方法来解析java变量中的sparql查询,比如python中的Fyzz?如何使用Jena或芝麻API?

2 个答案:

答案 0 :(得分:8)

您可以在语法或代数级别使用Apache Jena的ARQ非常简单地在Java中解析和操作SPARQL。 QueryFactory.create(queryString)将提供查询的java表示。然后四处寻找:

Query query = QueryFactory.create(queryString);
query.isSelectType() && query.isQueryResultStar(); // of the form SELECT *?
query.getDatasetDescription(); // FROM / FROM NAMED bits
query.getQueryPattern(); // The meat of the query, the WHERE bit
...etc etc..
Op op = Algebra.compile(query); // Get the algebra for the query

(见the Query java documentation

尝试从教程'Manipulating SPARQL using ARQ'开始。这将让您了解如何表示查询,以及如何从中提取信息(visitors特别有用)。虽然最初语法级别最为熟悉,但对于许多任务,algebra的效果更好,因为它对应于查询实际执行的操作。

答案 1 :(得分:4)

以下是使用Sesame解析和操作SPARQL查询的方法:

解析:

ParsedQuery pq = QueryParserUtil.parseQuery(QueryLanguage.SPARQL, queryString);

这是ParsedQuery的输出,它是查询的代数对象表示。如果您希望专门获取解析树本身,那也是可能的:

ASTQueryContainer parseTree = SyntaxTreeBuilder.parseQuery(queryString);

然后,您可以通过实现自定义SyntaxTreeBuilderVisitor直接操作此抽象语法树(提示:扩展ASTVisitorBase,这样您只需要覆盖实际想要执行某些操作的方法)。

如果我们回到代数模型,你可以在Sesame Sail Repository上执行ParsedQuery

if (pq instanceof ParsedTupleQuery) {
        SailTupleQuery query = new SailTupleQuery(pq, repositoryConnection);
        TupleQueryResult result = query.evaluate();
} else if (pq instanceof ParsedGraphQuery) {
        // etc for other query types
}

要在执行ParsedQuery之前操纵它,请使用QueryModelVisitor实施,例如你自己的自定义查询操纵器:

QueryModelVisitor myVisitor = new MyCustomQueryModelVisitor();
pq.getTupleExpr().visit(myVisitor);

使用这样的自定义查询模型访问者,您可以完全控制查询,优化查询或实际重写为不同的语法。

是否在抽象语法树(AST)级别或在查询模型级别执行此操作是一个品味问题:查询模型在查询规划/优化和部分重写方面为您提供更多灵活性(以便稍后在Sesame商店上执行),如果你的目标是为了另一个目的完全重写查询(例如在非Sesame商店上执行它),直接操作语法树可能会更容易。

顺便说一句,上面解析和执行查询的方法是一种迂回的做事方式。如果您在执行之前不需要操作已解析的查询,则可以在存储库中准备和执行查询,如下所示:

String queryString = "SELECT ...";
RepositoryConnection conn = repo.getConnection();
try {
   TupleQuery tq = conn.prepareTupleQuery(QueryLanguage.SPARQL, queryString);
   TupleQueryResult result = tq.evaluate();
}
finally {
   conn.close();
}