从 Wikidata 获取给定属性的别名值?

dar*_*rth 3 sparql wikidata

对于给定的属性,如'职业 (P106)',我想检索其所有别名,如:专业、工作、工作、职业、就业、工艺。所有这些都存在于属性维基数据页面的“也称为”下。我如何使用 SPARQL 检索此信息?我尝试使用以下查询。

  SELECT ?predicate ?object WHERE {
  wdt:P106 wdt:P1449 ?predicate .  //Nickname
  wdt:P106 wdt:P734 ?predicate .   //Family Name
  wdt:P106 wdt:P735 ?predicate .  //Given Name
  wdt:P106 skos:altLabel ?predicate . 
  SERVICE wikibase:label { bd:serviceParam wikibase:language "en". }
}
Run Code Online (Sandbox Code Playgroud)

Sta*_*lin 7

SELECT ?altLabel
{
 VALUES (?wd) {(wd:P106)}
 ?wd skos:altLabel ?altLabel .
 FILTER (lang(?altLabel) = "en")
}
Run Code Online (Sandbox Code Playgroud)

或者

SELECT ?altLabel
{
 VALUES (?wdt) {(wdt:P106)}
 ?wd wikibase:directClaim ?wdt .
 ?wd skos:altLabel ?altLabel .
 FILTER (lang(?altLabel) = "en")
}
Run Code Online (Sandbox Code Playgroud)

这些段落提供了一些解释:


更新

您仍然可以使用标签服务:

SELECT ?wdAltLabel
{
 VALUES (?wdt) {(wdt:P106)}
 ?wd wikibase:directClaim ?wdt .
 SERVICE wikibase:label { bd:serviceParam wikibase:language "en". }
}
Run Code Online (Sandbox Code Playgroud)