0

我正在尝试获取给定 Wikidata 项目的所有超名称的列表。例如,我想遍历https://www.wikidata.org/wiki/Q4421的“子类”元素。

https://query.wikidata.org的 SPARQL 命令是什么样的?

4

3 回答 3

3

您可以使用属性路径 (*) 语法。

在这种情况下 wdt:P279* 提到 0 次或更多时间 wdt:P279 是 Wikidata 模型中等效的子类。

我在这里添加了一些变化以包括深度,以便您可以订购它们

SELECT ?entity ?entityLabel (count(?mid) as ?depth) WHERE {
  wd:Q4421 wdt:P279* ?mid.
  ?mid wdt:P279* ?entity
  SERVICE wikibase:label { bd:serviceParam wikibase:language "en" }
} group by ?entity ?entityLabel
order by ?depth

https://query.wikidata.org/#SELECT%20%3Fentity%20%3FentityLabel%20%28count%28%3Fmid%29%20as%20%3Fdepth%29%20WHERE%20%7B%0A%20%20wd %3AQ4421%20wdt%3AP279%2a%20%3Fmid.%0A%20%20%3Fmid%20wdt%3AP279%2a%20%3Fentity%0A%20%20SERVICE%20wikibase%3Alabel%20%7B%0A%20% 20%20%20bd%3AserviceParam%20wikibase%3Alanguage%20%22en%22%20.%0A%20%20%20%7D%0A%7D%20group%20by%20%3Fentity%20%3FentityLabel%0Aorder%20by %20%3F深度

于 2016-07-30T05:06:31.673 回答
0

刚刚找到了一个可以解决我的问题的工具。 https://angryloki.github.io/wikidata-graph-builder/?property=P279&item=Q4421

于 2016-07-28T10:49:35.133 回答
0

您可以使用 SPARQL 递归语法*

SELECT ?entity WHERE {
  wd:Q4421 wdt:P279* ?entity.
}

参见 query.wikidata.org

于 2016-07-28T23:25:03.990 回答