Я новичок в Jena и SPAQL, пытаясь запустить jena в eclipse с кодом ниже, получив Query Parse Exception. Этот запрос выполняется отлично на http://dbpedia.org/sparql
Что я хочу - место рождения
исключение
com.hp.hpl.jena.query.QueryParseException: строка 1, столбец 84: неразрешенное префиксное имя: dbpedia-owl: birthPlace
запрос
PREFIX res: <http://dbpedia.org/resource/>
SELECT DISTINCT ?string
WHERE {
res:David_Cameron dbpedia-owl:birthPlace ?string .
}
Код Java
import org.apache.jena.atlas.logging.Log;
import com.hp.hpl.jena.query.QueryExecution;
import com.hp.hpl.jena.query.QueryExecutionFactory;
import com.hp.hpl.jena.query.QuerySolution;
import com.hp.hpl.jena.query.ResultSet;
import com.hp.hpl.jena.sparql.engine.http.QueryExceptionHTTP;
public class GetDateOfBirth {
private String service = null;
public GetDateOfBirth(String service)
{
this.service = service;
}
public void TestConnection(){
QueryExecution qe = QueryExecutionFactory.sparqlService(service, "ASK {}");
try{
if(qe.execAsk())
{
System.out.println(service + " is UP");
}
}catch(QueryExceptionHTTP e){
e.printStackTrace();
System.out.println(service + "is Down");
}
finally {
qe.close();
}
}
public ResultSet executeQuery(String queryString) throws Exception {
QueryExecution qe = QueryExecutionFactory.sparqlService(service, queryString);
return qe.execSelect();
}
public static void main(String[] args) {
Log.setCmdLogging() ;
String sparqlService = "http://dbpedia.org/sparql";
/*
* More query examples here:
* http://sparql.bioontology.org/examples
*/
String query = "PREFIX res: <http://dbpedia.org/resource/>" +
" SELECT ?dob WHERE { res:David_Cameron dbpedia-owl:birthPlace ?string .}";
try {
GetDateOfBirth con= new GetDateOfBirth(sparqlService);
ResultSet results = con.executeQuery(query);
for ( ; results.hasNext() ; ) {
QuerySolution soln = results.nextSolution() ;
System.out.println(soln.getResource("?dob").toString());
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
Так же, как вы определили префикс PREFIX res: <http://dbpedia.org/resource/>
, вам нужно указать префикс для dbpedia-owl
. Используя предварительные префиксы префикса пространства имен DBPedia, я предполагаю, что обновленный запрос будет выглядеть так:
PREFIX res: <http://dbpedia.org/resource/>
PREFIX dbpedia-owl: <http://dbpedia.org/ontology/>
SELECT DISTINCT ?string
WHERE {
res:David_Cameron dbpedia-owl:birthPlace ?string .
}