如何获取Jena查询的所有主题?

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),但是我似乎无法找到任何具体的查询主题(所有结果变量的列表也将返回谓词和对象).

任何帮助赞赏.

use*_*512 9

有趣的问题.您需要做的是完成查询,并为每个三元组迭代并查看第一部分.

最强大的方法是通过元素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)

  • 您需要在ElementPathBlock中查找SPARQL 1.1以及ElementTriplesBlock.请参见PatternVarsVisitor (2认同)