我有这个问题.它匹配名称中包含"South"的任何内容.但我只想要一个foaf:name正是"南方"的人.
SELECT Distinct ?TypeLabel
WHERE
{
?a foaf:name "South" .
?a rdf:type ?Type .
?Type rdfs:label ?TypeLabel .
}
Run Code Online (Sandbox Code Playgroud)
有点迟了但无论如何......我认为这就是你要找的东西:
SELECT Distinct ?TypeLabel Where {
?a foaf:name ?name .
?a rdf:type ?Type .
?Type rdfs:label ?TypeLabel .
FILTER (?name="South"^^xsd:string)
}
Run Code Online (Sandbox Code Playgroud)
您可以将FILTER与xsd类型一起使用以限制结果.希望这有助于...干杯!
(为此打破评论)
问题是数据,而不是您的查询。如果使用以下查询:
SELECT DISTINCT ?a
WHERE {
?a foaf:name "Imran Khan" .
}
Run Code Online (Sandbox Code Playgroud)
你找到(正如你所说的)“Imran Khan Niazy”。但是查看Imran Khan的 dbpedia 条目,您会看到两者:
foaf:name "Imran Khan Niazy"
foaf:name "Imran Khan"
Run Code Online (Sandbox Code Playgroud)
这是因为 RDF 允许重复使用属性。
“South”也有同样的问题(专辑、艺术家和奇怪的“South Luton”)。在这些情况下,为了正确性或消除歧义,既有熟悉的名称(“Imran Khan”、“South”),也有更精确的名称(“Imran Khan Niazy”、“South(专辑)”)。
如果您想要更精确的匹配,请尝试添加类型(例如专辑的http://dbpedia.org/ontology/MusicalWork )。
请注意,DBpedia 源自维基百科,并且提取过程并不完美。这是一个充满了不稳定数据的区域,所以不要假设您的查询出了问题。