首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么查询一个子类的所有实例比查询"parent“类得到更多的结果?

为什么查询一个子类的所有实例比查询"parent“类得到更多的结果?
EN

Stack Overflow用户
提问于 2017-01-23 13:30:40
回答 1查看 66关注 0票数 2

根据维基数据,战斗是军事行动的一个子类。然而,当我查询所有军事行动的实例时,我得到了699个结果,而对于所有的战斗,我得到了7399个结果。

军事行动查询

代码语言:javascript
复制
SELECT ?label WHERE {
  ?subj wdt:P31* wd:Q645883.
  ?subj rdfs:label ?label.
  FILTER((LANG(?label)) = "en")
}

查询战斗

代码语言:javascript
复制
SELECT ?label WHERE {
  ?subj wdt:P31* wd:Q178561.
  ?subj rdfs:label ?label.
  FILTER((LANG(?label)) = "en")
}

军事行动:https://www.wikidata.org/wiki/Q645883

战斗:https://www.wikidata.org/wiki/Q178561

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-23 14:17:34

因为您的SPARQL查询,特别是属性路径是错误的。类型通过subClassOf (wdt:P279)连接,但在使用wdt:P31*时要求关闭instance-of关系

它必须是wdt:P31/wdt:P279*

有关区别,请参阅https://www.wikidata.org/wiki/Property:P279https://www.wikidata.org/wiki/Property:P31

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41799780

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档