11

有什么简单的方法可以解析java变量中的sparql查询,比如python中的Fyzz?如何使用 Jena 或 sesame API?

4

2 回答 2

9

您可以使用 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

(请参阅查询 java 文档

尝试从教程“使用 ARQ 操作 SPARQL”开始。这将使您了解查询是如何表示的,以及如何从中提取内容(visitors特别有用)。尽管最初语法级别是最熟悉的,但对于许多任务,代数工作得更好,因为它对应于查询实际执行的操作。

于 2013-01-24T12:01:33.633 回答
5

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

解析:

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

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

ASTQueryContainer parseTree = SyntaxTreeBuilder.parseQuery(queryString);

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

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

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();
}
于 2013-01-24T22:33:42.663 回答