我希望获得具有指定类别和指定键的所有页面。我的问题:
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 query
至少应该返回此页面:http://dbpedia.org/page/Duinrell(因为它符合条件)。
有什么想法吗?
答案 0 :(得分:6)
您的查询存在一些问题。首先,在比较URI时不要使用正则表达式。而不是:
regex(?cat, "category:Amusement_parks_in_the_Netherlands")
使用:
?cat = <http://dbpedia.org/resource/category:Amusement_parks_in_the_Netherlands>
第二:你的dublin核心的命名空间前缀似乎错了。您正在查询属性dcterms:subject
,并且在查询中,前缀dcterms
被映射到名称空间http://dublincore.org/2010/10/11/dcterms.rdf#
。但是,DBPedia中的实际属性为http://purl.org/dc/terms/subject
,因此您的命名空间前缀应该映射到http://purl.org/dc/terms/
。