问题描述
我正在尝试创建一个 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]". }
}
这里我附上了我用来获取所有必需信息的查询。 我真的被这个问题困住了。如果能提供任何帮助,我将不胜感激。
解决方法
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]". } }