如何在SPARQL中精确匹配字符串? [英] How to match exact string literals in SPARQL?
本文介绍了如何在SPARQL中精确匹配字符串?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有这个查询。它和名字中有"南方"的任何东西都匹配。但是我只想要foaf:name
正好是"South"的那个。
SELECT Distinct ?TypeLabel
WHERE
{
?a foaf:name "South" .
?a rdf:type ?Type .
?Type rdfs:label ?TypeLabel .
}
推荐答案
(不再对此发表评论)
数据问题
问题在于数据,而不是您的查询。如果使用以下查询:
SELECT DISTINCT ?a
WHERE {
?a foaf:name "Imran Khan" .
}
您会发现(如您所说)"Imran Khan Niazy"(伊姆兰·汗·尼亚齐)。 但是查看Imran Khan的DBpedia条目,您会看到两者都有:
foaf:name "Imran Khan Niazy"
foaf:name "Imran Khan"
这是因为RDF允许重复使用属性。
原因
"South"也有同样的问题(专辑、艺术家和奇怪的"South Luton")。在这些情况下,为了正确或消除歧义,既有熟悉的名称("Imran Khan"、"South"),也有更精确的名称("Imran Khan Niazy"、"South(Alignment)")。
解决方案
如果您想要更精确的匹配,请尝试添加类型(例如http://dbpedia.org/ontology/MusicalWork相册)。注意
请注意,DBpedia派生自Wikipedia,提取过程并不完美。这是一个数据不可靠的区域,所以不要假设您的查询出错。
这篇关于如何在SPARQL中精确匹配字符串?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文