Sparql with Java Jena



我正在使用Wikidata查询服务中的下一个查询:

PREFIX wd: <http://www.wikidata.org/entity/> 
PREFIX wdt: <http://www.wikidata.org/prop/direct/>  
PREFIX xsd: <www.w3.org/2001/XMLSchema#>  
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>  
select ?lexemeId ?lemma WHERE { 
?lexemeId <http://purl.org/dc/terms/language> wd:Q1860.
?lexemeId wikibase:lemma ?lemma.
FILTER (regex(?lemma, '^bank.*'))
}

在执行时工作良好https://query.wikidata.org/但是,如果尝试使用JavaJena,它会失败,原因是:

Exception in thread "main" org.apache.jena.query.QueryParseException: Line 7, column 11: Unresolved prefixed name: wikibase:lemma

它无法将wikibase解析为前缀。有线索吗?提前好了,大卫。

当您使用他们的SPARQL查询页面时,会预先声明许多前缀,包括wikibase。当远程查询端点时,必须声明这些。因此,在查询中使用PREFIX wikibase: <http://wikiba.se/ontology#>

wiki 中提供了前缀列表

最新更新