1

这是这个问题的演变。

基本上,我无法从远程端点获取 SPARQL 查询的所有解决方案。我在这里通读了第 2.4 节,因为它似乎描述了与我的情况几乎相同的情况。

这个想法是我想根据我本地 RDF 图中的信息从 DBPedia 过滤我的结果。查询在这里:

PREFIX ns1:             
<http://www.semanticweb.org/caeleanb/ontologies/twittermap#>
PREFIX dbo: <http://dbpedia.org/ontology/>

SELECT *
WHERE {
  ?p ns1:displayName ?name .
  SERVICE <http://dbpedia.org/sparql> {
    ?s rdfs:label ?name .
    ?s rdf:type foaf:Person .
  }
}

我得到的唯一结果是 dbpedia:John_McCain (for ?s)。我认为这是因为 John McCain 是第一个“x”结果中的唯一匹配项,但我不知道如何让查询返回所有匹配项。例如,如果我添加如下过滤器:

SERVICE <http://dbpedia.org/sparql> {
  ?s rdfs:label ?name .
  ?s rdf:type foaf:Person .
  FILTER(?name = "John McCain"@en || ?name = "Jamie Oliver"@en)
}

然后它正确返回 dbpedia:Jamie_Oliver 和 dbpedia:John_McCain。除非我专门将其添加到像这样的过滤器中,否则还有许多其他比赛(例如 Jamie Oliver)无法通过。

有人可以解释一种提取其余匹配项的方法吗?谢谢。

4

1 回答 1

2

看起来这个问题的原因是 SERVICE 块试图从 DBPedia 中提取所有 foaf:Persons,然后根据我的本地 Stardog db 过滤它们。由于查询 DBPedia 时有 10,000 个结果限制,因此只会找到出现在该 10,000 个任意 Persons 集合中的匹配项。为了解决这个问题,我编写了一个脚本来组合一个 FILTER 块,其中包含我的 Stardog db 中的每个字符串名称,并将其附加到 SERVICE 块以进行远程过滤,从而避免达到 10,000 个结果限制。它看起来像这样:

PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX dbo: <http://dbpedia.org/ontology/>
PREFIX dbr: <http://dbpedia.org/resource/>
PREFIX foaf: <http://xmlns.com/foaf/0.1/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
PREFIX dbo: <http://dbpedia.org/ontology/>
PREFIX ns1: <http://www.semanticweb.org/caeleanb/ontologies/twittermap#>

CONSTRUCT{
  ?s rdf:type ns1:Person ;
    ns1:Politician .
}
WHERE {
    ?s rdfs:label ?name .
    ?s rdf:type dbo:Politician .
    FILTER(?name IN ("John McCain"@en, ...)
}
于 2017-10-22T12:39:37.177 回答