如何匹配SPARQL中的确切字符串文字?

Tas*_*han 6 sparql

我有这个问题.它匹配名称中包含"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)

Luc*_*ira 5

有点迟了但无论如何......我认为这就是你要找的东西:

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类型一起使用以限制结果.希望这有助于...干杯!


use*_*512 4

(为此打破评论)

数据问题

问题是数据,而不是您的查询。如果使用以下查询:

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 源自维基百科,并且提取过程并不完美。这是一个充满了不稳定数据的区域,所以不要假设您的查询出了问题。

  • 我在[此处](http://dbpedia.org/snorql/?query=SELECT+DISTINCT+%3Fa+%0D%0AWHERE+%7B+%0D%0A++++%3Fa 得到相同查询[无结果]的原因可能是什么+foaf%3Aname+%22Imran+Khan%22+.+%0D%0A%7D) (2认同)