问题描述
我试图获取在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 (将#修改为@)