SPARQL-查询属性并返回相关属性的结果 [英] SPARQL - query a property and return results for a related property
本文介绍了SPARQL-查询属性并返回相关属性的结果的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我是SPARQL新手,我正在尝试运行SPARQL查询,以便返回属性的结果,并据此列出相关属性的值。
示例代码为:
SELECT ?player ?position ?club ?goals WHERE {
?player a <http://dbpedia.org/ontology/SoccerManager> . filter (contains (str(?player), "Alan_Shearer")) .
?player <http://dbpedia.org/ontology/position> ?position .
?player <http://dbpedia.org/property/clubs> ?club .
?player <http://dbpedia.org/property/goals> ?goals .
}
结果是针对每个俱乐部复制所有目标:
player position club goals
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Southampton_F.C. 23
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Southampton_F.C. 112
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Southampton_F.C. 148
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Newcastle_United_F.C. 23
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Newcastle_United_F.C. 112
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Newcastle_United_F.C. 148
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Blackburn_Rovers_F.C. 23
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Blackburn_Rovers_F.C. 112
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Blackburn_Rovers_F.C. 148
每个俱乐部的进球在数据集中关联正确,因此我只想获取各个俱乐部的进球:
player position club goals
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Southampton_F.C. 23
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Newcastle_United_F.C. 112
http://dbpedia.org/resource/Alan_Shearer http://dbpedia.org/resource/Forward_(association_football) http://dbpedia.org/resource/Blackburn_Rovers_F.C. 148
但是,我不了解如何在SPARQL中做到这一点,任何帮助都是非常感谢的。
推荐答案
请注意,数据中有一些DBpedia-OWL:CareerStation属性值:
dbpedia-owl:careerStation dbpedia:Alan_Shearer__1, dbpedia:Alan_Shearer__2, ...
如果您查看这些属性的值,例如http://dbpedia.org/page/Alan_Shearer__3,您可以看到其中一些具有许多目标属性。这意味着您可以执行以下操作:
select ?player ?position ?team ?goals {
values ?player { dbpedia:Alan_Shearer }
?player dbpedia-owl:position ?position ;
dbpedia-owl:careerStation [ dbpedia-owl:team ?team ;
dbpedia-owl:numberOfGoals ?goals ] .
}
由于并非所有电台都有目标信息,您可能希望在此处使用可选选项获取电台,然后使用目标(如果可用):
select ?player ?position ?team ?goals {
values ?player { dbpedia:Alan_Shearer }
?player dbpedia-owl:position ?position ;
dbpedia-owl:careerStation ?station .
?station dbpedia-owl:team ?team .
optional { ?station dbpedia-owl:numberOfGoals ?goals }
}
这篇关于SPARQL-查询属性并返回相关属性的结果的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文