如何解决维基数据查询遗漏结果
我正在尝试从 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}
}
自己去看看。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。