问题描述
我正在尝试从 Wikidata (query link) 中查询所有国家/地区:
SELECT ?item WHERE { ?item wdt:P31 wd:Q6256. }
不幸的是,结果缺失,例如瑞士 (Q39
):
https://www.wikidata.org/wiki/Q39
查看瑞士数据,它有三元组:instance of
(P31) country
(Q6256)。
你能帮我理解为什么 Q39
没有出现在结果中吗?
谢谢!
解决方法
在维基数据中,通常有所谓的陈述。这些允许对这些陈述进行限定。 例如,在瑞士是一个国家的情况下,条件是该语句的排名应该是“正常”而不是首选。 提及瑞士的首选方式是主权国家 (wd:Q3624078),而且 WikiData 似乎仅在实体与其“首选等级”分类之间具有 wdt:P31 关系,如此 query 所示。
我认为这可能是因为“国家”是一个更通用的概念,例如威尔士是一个国家,但不是一个主权国家。
不过不要害怕,因为这个查询:
SELECT DISTINCT ?item
WHERE {
?item p:P31/ps:P31 wd:Q6256.
}
也返回 wd:Q39。这个查询所做的是从瑞士导航到国家通过语句。 也就是说,我们的数据中有:
wd:Q39 p:P31 wds:Q39-fbe1ac75-4a8a-93c4-6009-81055d79f9cb .
wds:Q39-fbe1ac75-4a8a-93c4-6009-81055d79f9cb ps:P31 wd:Q6256 .
但不是:
wd:Q39 wdt:P31 wd:Q6256 .
试试这个:
SELECT DISTINCT *
WHERE {
?item p:P31 ?y .
?y ps:P31 wd:Q6256 ;
?p ?o .
VALUES ?item {wd:Q39}
}
自己去看看。