Sparql 查询维基数据以从属性

我正在尝试创建一个 wiki 数据 SParqL 查询。我想要做的是从某个属性中获取多个项目 例如: 我正在尝试获取所有具有统计包实例属性的数据。 但我面临的问题是,例如社会科学统计包的属性类型为 348,它有多个版本。如果版本也有发布日期,我想获取所有这些版本以及发布日期。 我阅读了一些文档并尝试创建一个查询,但我无法从属性 p:348 中获取所有版本。

SELECT ?software ?softwareLabel ?developerLabel ?versionLabel ?date
WHERE
{
  ?software wdt:P31 wd:Q13199995 . 
   OPTIONAL { ?software wdt:P178 ?developer. }
  OPTIONAL { ?software  wdt:P348 ?version. }
   OPTIONAL { 
  FILTER EXISTS {
       ?software wdt:P348 ?version2. 
      FILTER ( ?version != ?version2 )
      }
     }

  SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE]". }
}

这里我附上了我用来获取所有必需信息的查询。 我真的被这个问题困住了。如果能提供任何帮助,我将不胜感激。

iCMS 回答:Sparql 查询维基数据以从属性

UNION 或 VALUES 都是你的朋友:

SELECT ?software ?softwareLabel ?developerLabel
    ?versionLabel ?date WHERE {   VALUES ?type 
    {wd:Q7397 wd:Q13199995 wd:Q166142}   ?software wdt:P31 ?type   
    OPTIONAL { ?software wdt:P178 ?developer. }  
    OPTIONAL {     ?software p:P348 ?stmt.    
    ?stmt ps:P348 ?version.     
    OPTIONAL { ?stmt pq:P577 ?date. }   }   
    SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE]". } }
本文链接:https://www.f2er.com/166659.html

大家都在问