使用 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());
我正在尝试使用 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());