如何解决Sparql:如何从两个属性中获取值,但是如果找到属性值则停止
我试图获取在rdfs:label或skos:altLabel中具有标签的?wdProperty1,但是如果在rdfs:label中已经找到“长度”值,我希望查询停止搜索skos:altLabel。这是出于效率目的,下面的查询从实际查询中简化了。我尝试使用“?”但是它仍然从这两个属性返回?wdProperty1。
SELECT disTINCT *
WHERE
{
?wdProperty1 ( rdfs:label | (skos:altLabel)? ) "length"@en;
}
LIMIT 10
编辑:这是我在算法解释中要实现的目标
if ( ?wdProperty1 rdfs:label "length" )
{
print "length exist in rdfs:label"
}
else if( ?wdProperty1 skos:label "length" )
{
print "length exist in skos:label"
}
原因是我想这样做是为了提高效率,因为rdfs:label和skos:altLabel中都可以存在相同的标签,但是我只需要知道一个标签,但是此查询将返回多个?ent和?wdtPorperty,因此“?ent?wdtProperty1?val”的声明。不必经历太多的排列。例如下面的查询以查找灯泡的发明人。
SELECT disTINCT ?ent ?wdtProperty ?val ?valLabel
WHERE {
VALUES ?label1 { rdfs:label skos:altLabel } ?ent ?label1 "light bulb"@en.
VALUES ?labelB1 { rdfs:label skos:altLabel } ?wdProperty1 ?labelB1 "inventor"@en;
wikibase:directClaim ?wdtProperty1.
?ent ?wdtProperty1 ?val.
OPTIONAL { ?val rdfs:label ?valLabel FILTER(lang(?valLabel) = "en") }
}
LIMIT 10
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。