当我在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')
}
SPARQL结果
如果?name
只有一个值,并且没有选择该变量,则可以将其写入查询中:
select distinct ?abstract where {
[ rdfs:label "New York"@en ;
dbpedia-owl:abstract ?abstract ]
filter langMatches(lang(?abstract),'en')
}