4

我想获取所有具有指定类别和指定键的页面。我的查询:

PREFIX dbpedia: <http://dbpedia.org/>
PREFIX dbpedia2: <http://dbpedia.org/property/> 
PREFIX dbpedia-owl: <http://dbpedia.org/ontology/>
PREFIX dcterms: <http://dublincore.org/2010/10/11/dcterms.rdf#>
PREFIX foaf: <http://xmlns.com/foaf/0.1/>
PREFIX geo: <http://www.w3.org/2003/01/geo/wgs84_pos#>
PREFIX grs: <http://www.georss.org/georss/point>
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT ?page ?cat ?key ?value (lang(?value) as ?language) WHERE {

  ?page dcterms:subject ?cat .
  ?page ?key ?value .

  FILTER(
    regex(?cat, "category:Amusement_parks_in_the_Netherlands") &&
    ?key = foaf:depiction
  )

}

但它返回零结果。请参见此处:SNORQL 查询

它至少应该返回这个页面:http ://dbpedia.org/page/Duinrell (因为它符合标准)。

有任何想法吗?

4

1 回答 1

6

您的查询有几处问题。首先,在比较 URI 时不要使用正则表达式。代替:

regex(?cat, "category:Amusement_parks_in_the_Netherlands")

利用:

?cat = <http://dbpedia.org/resource/category:Amusement_parks_in_the_Netherlands>

第二:都柏林核心的命名空间前缀似乎是错误的。您正在查询 property dcterms:subject,并且在您的查询中,前缀dcterms映射到 namespace http://dublincore.org/2010/10/11/dcterms.rdf#。但是,DBPedia 中的实际属性是http://purl.org/dc/terms/subject,因此您的命名空间前缀应该映射到http://purl.org/dc/terms/

于 2012-01-22T04:45:47.077 回答