问题描述
我需要一个SPARQL查询,该查询返回特定的Wikidata ID或ID列表。在现实生活中,这种查询是没有用的,但出于测试目的,我需要它。
我能想到的最简单的变体是:
SELECT disTINCT ?s
WHERE
{
?s ?p ?o
FILTER (?s = wd:Q151345).
}
我必须使用disTINCT
,因为?s ?p ?o
会匹配Q151345中的每个三元组,如果我省略它,则它输出的项目是它的属性值对的多少倍。
有没有更简单的方法?
解决方法
使用关键字VALUES,可以使用多个实例。
PREFIX bd: <http://www.bigdata.com/rdf#>
PREFIX wd: <http://www.wikidata.org/entity/>
PREFIX wdt: <http://www.wikidata.org/prop/direct/>
PREFIX wikibase: <http://wikiba.se/ontology#>
SELECT ?s
WHERE
{
VALUES ?s { wd:Q151345 wd:Q2996394 }
?s ?p ?o
}
LIMIT 10
演示:http://linkedwiki.com/query/Query_multiple_instance_of_in_same_query