[英]Query DBpedia with Sparql using VALUES
当我在Java中运行此代码时,出现错误,我认为该错误是由于“字符串值”引起的。 我不确定是否要添加它,但是我是从上一个问题的答案中得到这个想法的,我在本网站的查询DBpedia中要求获取不同输入的摘要
public static void DbpediaResultSparql() {
String values = "New York";
String service = "http://dbpedia.org/sparql";
String sparqlQueryString2 = "PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>"+
"PREFIX dbpedia-owl: <http://dbpedia.org/ontology/>"+
"PREFIX dbpedia: <http://dbpedia.org/resource/>"+
"SELECT DISTINCT ?abstract"+
"WHERE"+
"{ _:b0 rdfs:label ?name ."+
"_:b0 dbpedia-owl:abstract ?abstract"+
"FILTER langMatches(lang(?abstract), 'en')"+
"?name { " + values +" @en }"+
"}" ;
Query query = QueryFactory.create(sparqlQueryString2);
ARQ.getContext().setTrue(ARQ.useSAX);
// Executing SPARQL Query and pointing to the DBpedia SPARQL Endpoint
QueryExecution qexec = QueryExecutionFactory.sparqlService(
"http://DBpedia.org/sparql", query);
// Retrieving the SPARQL Query results
ResultSet results = qexec.execSelect();
// Iterating over the SPARQL Query results
while (results.hasNext()) {
QuerySolution soln = results.nextSolution();
// Printing DBpedia entries' abstract.
System.out.println(soln.get("?abstract"));
}
qexec.close();
}
您不会通过以下代码获得有用的答案
"SELECT DISTINCT ?abstract"+ "WHERE"
"_:b0 dbpedia-owl:abstract ?abstract"+ "FILTER langMatches(lang(?abstract), 'en')"
因为它变成了
SELECT DISTINCT ?abstractWHERE
_:b0 dbpedia-owl:abstract ?abstractFILTER
并且您不想要名为?abstractWHERE
或?abstractFILTER
变量。
这也没有任何意义:
String values = "New York";
"?name { " + values +" @en }"
你最终会得到
?name { New York@en }
我希望你想要的是
values ?name { "New York"@en }
我建议您看一下ParameterizedSparqlStrings ,并确保在代码中添加终止换行符或至少使用空格。 如果您刚刚打印出查询,则可以将其放入sparql.org的查询验证器中,您会立即发现问题。
您可以这样编写查询:
select distinct ?abstract where {
values ?name { "New York"@en }
[ rdfs:label ?name ;
dbpedia-owl:abstract ?abstract ]
filter langMatches(lang(?abstract),'en')
}
如果您只有?name
一个值,并且没有选择该变量,则可以在查询中将其写入:
select distinct ?abstract where {
[ rdfs:label "New York"@en ;
dbpedia-owl:abstract ?abstract ]
filter langMatches(lang(?abstract),'en')
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.