0
這是我的java代碼,我試圖用jena查詢我的rdf文件,但它給了我關於文字的例外。我使用protege工具設計了rdf文件,並試圖用jena來查詢它。使用jena fuseki服務器查詢rdf文件時得到異常
Exception in thread "main" java.lang.ClassCastException: com.hp.hpl.jena.rdf.model.impl.ResourceImpl cannot be cast to com.hp.hpl.jena.rdf.model.Literal
at com.hp.hpl.jena.sparql.core.QuerySolutionBase.getLiteral(QuerySolutionBase.java:26)
at emotion.sparqltest(emotion.java:36)
at emotion.main(emotion.java:16)
我的Java代碼如下...
import com.hp.hpl.jena.query.Query;
import com.hp.hpl.jena.query.QueryFactory;
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.rdf.model.Literal;
import com.hp.hpl.jena.rdf.model.Model;
import com.hp.hpl.jena.util.FileManager;
public class emotion {
public static void main(String[] args) {
// TODO Auto-generated method stub
sparqltest();}
static void sparqltest()
{
FileManager.get().addLocatorClassLoader(emotion.class.getClassLoader());
Model model= FileManager.get().loadModel("C:/Users/avg/workspacejena32/Jena/bin/emotion.rdf");
String queryString="PREFIX uni:<http://www.semanticweb.org/avg/ontologies/2016/2/untitled-ontology-5#>" +
"SELECT * WHERE {" +
"uni:angry uni:says ?x}";
Query query= QueryFactory.create(queryString);
QueryExecution qexec=QueryExecutionFactory.create(query, model);
try {
ResultSet results = qexec.execSelect();while (results.hasNext()){
QuerySolution soln = results.nextSolution();
Literal name = soln.getLiteral("x");
System.out.println(name);
}
}
finally {
qexec.close();
}}}
如果我這樣做,我這樣的查詢
"uni:angry uni:says ?words"
然後一些變化,我得到空結果如下
null
null
那我該怎麼辦?我沒有得到任何如何解決它? –
@AshutoshVikramsingGirase一個好的IDE應該提供'soln'對象上可用的其他方法。那麼[QuerySolution **的javadoc]也是如此。還有一個返回資源的getResource()方法,以及一個返回RDFNode的get()方法。其中任何一個都可以爲您提供資源。 –