使用 rdf4j 构建 sparql 查询

问题描述

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

我是 Java 的新手(以及 stackoverflow,如果写得不好,请见谅),但我认为我已经包含了正确的开始步骤。我通过以下方式实例化了一个选择查询一个前缀和一个变量:

    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“book”。我不想查询多个变量(例如: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());

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...