如何在SPARQL中精确匹配字符串? [英] How to match exact string literals in SPARQL?

查看:19
本文介绍了如何在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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆