如何使用SPARQL查询从Wikidata通过ID查询特定实体?

问题描述

我需要一个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

文档:https://www.w3.org/TR/sparql11-query/#inline-data

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...