使用 rdf4j 构建 sparql 查询

Constructing a sparql query using rdf4j

我正在尝试使用 rdf4j 文档构建 SPARQL 查询:https://rdf4j.org/documentation/tutorials/sparqlbuilder/

我是 java 的新手(和 Whosebug,如果写得不好,我深表歉意),但我认为我已经包含了正确的开始步骤。我通过以下方式实例化了一个 select 查询、一个前缀和一个变量:

    SelectQuery draftQuery = Queries.SELECT();

    Prefix default = SparqlBuilder.prefix("dc", Rdf.iri("url"));

    Variable draftCount = SparqlBuilder.var("draftCount");

url 已替换为正确的前缀

我想写的查询是:SELECT ?x WHERE { :team_1 :draftCount ?x},但是 ?x 没有 rdf:type,只是一个值附加到 :draftCount。我不知道如何将它写成 java 中的 SPARQL 查询,因为根据我在文档中的理解,示例包括产品是一本书,产品有 rdf:type “书”。我不想查询多个变量(例如:team_1 ?x ?y),因为团队中还有其他三元组,我想单独查询它们。我想稍后再进行另一个类似的 SPARQL 查询 SELECT ?x WHERE { :team_1 :completedCount ?x},

如何编写此查询?这是我目前所拥有的:

    draftQuery.prefix(default).select(draftCount)

你开了一个好头,但你混淆了变量和 IRI::team_1:draftCount 是查询中的 IRI,而不是变量。只有 ?x 是一个变量。由于您正在为 IR 使用默认命名空间,因此只需为默认命名空间创建一个 Prefix 对象,如下所示:

Prefix defaultNs = SparqlBuilder.prefix(Rdf.iri("http://example.org/"));

然后您可以使用它来创建 Iri 对象以用于查询,如下所示:

Iri team1 = defaultNs.iri("team_1");

要使用 SparqlBuilder 添加 rdf:type 以外的关系,请使用 .has 方法。

将它们放在一起,生成这个 SPARQL 查询字符串:

PREFIX: <http://example.org/>
SELECT ?x WHERE { :team_1 :draftCount ?x}

你这样做:

Prefix defaultNs = SparqlBuilder.prefix(Rdf.iri("http://example.org/"));
Iri team_1 = defaultNs.iri("team_1"), draftCount = defaultNs.iri("draftCount");
Variable x = SparqlBuilder.var("x");
        
SelectQuery query = Queries.SELECT()
            .prefix(defaultNs)
            .select(x)
            .where(team_1.has(draftCount, x));

System.out.println(query.getQueryString());