Nic*_*ett 8 java semantic-web sparql jena
假设我有一些jena查询对象:
String query = "SELECT * WHERE{ ?s <some_uri> ?o ...etc. }";
Query q = QueryFactory.create(query, Syntax.syntaxARQ);
Run Code Online (Sandbox Code Playgroud)
在查询中获取三元组的所有主题的最佳方法是什么?优选地,不必手动进行任何字符串解析/操作.
例如,给定一个查询
SELECT * WHERE {
?s ?p ?o;
?p2 ?o2.
?s2 ?p3 ?o3.
?s3 ?p4 ?o4.
<http://example.com> ?p5 ?o5.
}
Run Code Online (Sandbox Code Playgroud)
我希望能够返回一些看起来像的列表
[?s, ?s2, ?s3, <http://example.com>]
Run Code Online (Sandbox Code Playgroud)
换句话说,我想要查询中所有主题的列表.即使只有那些变量或文字/ uris的主题也会有用,但我想查找查询中所有主题的列表.
我知道有方法可以返回结果变量(Query.getResultVars)和其他一些信息(参见http://jena.apache.org/documentation/javadoc/arq/com/hp/hpl/jena/query/Query.html),但是我似乎无法找到任何具体的查询主题(所有结果变量的列表也将返回谓词和对象).
任何帮助赞赏.
有趣的问题.您需要做的是完成查询,并为每个三元组迭代并查看第一部分.
最强大的方法是通过元素walker来完成查询的每个部分.这似乎在你的情况顶部,但查询可以包含各种各样的事情,包括FILTERs,OPTIONALs和嵌套SELECTs.使用walker意味着您可以忽略这些内容并仅关注您想要的内容:
Query q = QueryFactory.create(query); // SPARQL 1.1
// Remember distinct subjects in this
final Set<Node> subjects = new HashSet<Node>();
// This will walk through all parts of the query
ElementWalker.walk(q.getQueryPattern(),
// For each element...
new ElementVisitorBase() {
// ...when it's a block of triples...
public void visit(ElementPathBlock el) {
// ...go through all the triples...
Iterator<TriplePath> triples = el.patternElts();
while (triples.hasNext()) {
// ...and grab the subject
subjects.add(triples.next().getSubject());
}
}
}
);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1849 次 |
| 最近记录: |