使用 SPARQL wikidata 查询选择来自两个或多个国家的足球运动员

问题描述

我正在尝试获取每个国家/地区维基百科上所有足球运动员的出生日期。到目前为止,我已经设法获得了一个国家/地区的所有数据,但我想同时获得多个国家/地区的数据,例如:

SELECT ?person ?dateOfBirth
WHERE {
  ?person wdt:P1532 wd:Q16 OR ?person wdt:P1532 wd:Q141;
  wdt:P569 ?dateOfBirth.
  SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". }
}

Q16 是加拿大,Q141 是阿根廷

谢谢!

解决方法

为了不将您的查询限制在单个国家/地区,请将 wd:Q16 替换为变量,即 ?person wdt:P1531 ?country

然后您需要将查询限制为足球运动员。 这可以通过以下行来完成

?person wdt:P106 wd:Q937857.

而且您可能想要玩家的名字,而不仅仅是 der ID。因此,在“选择”之后添加 ?personLabel

组合,查询读取

SELECT ?person ?personLabel ?country ?countryLabel ?dateOfBirth
WHERE {
  ?person wdt:P106 wd:Q937857;
          wdt:P1532 ?country;          
          wdt:P569 ?dateOfBirth.
  SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". }  
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...