我正在使用 Jena-extras 中的 Jena 查询生成器,我想知道是否有办法将 SERVICE 子句添加到 SelectBuilder 对象。
我的代码现在看起来像这样:
SelectBuilder builder = new SelectBuilder()
.addPrefix( "rdf", "http://www.w3.org/1999/02/22-rdf-syntax-ns#" )
.addPrefix("dbo", "http://dbpedia.org/ontology/")
.addVar("?uri")
.addWhere("?uri", "rdf:type", "dbo:Company")
.setLimit(100);
Query query = builder.build();
System.out.println(query);
输出这个:
PREFIX dbo: <http://dbpedia.org/ontology/>
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
SELECT ?uri
WHERE
{ ?uri rdf:type dbo:Company}
LIMIT 100
我还尝试在调用 builder.build() 后将 SERVICE 子句添加到 Query 对象,但似乎只能通过 ARQ API 使用body.addElement(new ElementService("http://any.domain/sparql", elementBlock))
. 问题是您无法从 Query 对象或 SelectBuilder 对象中获取 elementBlock。
有没有办法使用查询构建器添加 SERVICE 子句,或者是否有已知的解决方法而不求助于冗长的 ARQ API,或者我应该尝试自己扩展 SelectBuilder API?