我有一个本体(dgo.owl)和一个简单的程序(SparqlQuery.java)来查询相同的本体。在运行查询时我没有得到任何结果。经过长时间的调试我认为它会是很高兴把它放在社区中。
查询脚本如下:
OntModel ontmodque = ModelFactory.createOntologyModel(OntModelSpec.OWL_DL_MEM);
InputStream in=FileManager.get().open("ontologies/dgo.owl");
if (ontmodque.isEmpty())
{
ontmodque.read(in,"RDF/XML");
}
String qr= "PREFIX ssn: <http://purl.oclc.org/NET/ssnx/ssn#>\n" +
"PREFIX dgo: <http://www.iiitd.edu.in/~haroonr/ontologies/DGO#>\n" +
"SELECT \n"+
"?property \n"+
"WHERE\n"+
"{ \n"+
"dgo:DiningRoom ssn:hasProperty ?property .\n " +
"}";
Query qy = QueryFactory.create(qr);
QueryExecution qe = QueryExecutionFactory.create(qy,ontmodque);
ResultSet rs= qe.execSelect();
ResultSetFormatter.out(System.out, rs, qy) ;
ontmodque.close();
qe.close();
获得的输出是:
我知道 hasProperty 对象关系存在于所述本体中。此外,DiningRoom的可能属性应返回Illuminance,Temperature,Co2Content,AbsoluteHumidity。
答案 0 :(得分:5)
我认为您忘记了如何在OWL中定义属性。您已定义:
Class: DiningRoom subClassOf: hasProperty some AbsoluteHumidity
因此,您需要编写更复杂的查询:
PREFIX ssn: <http://purl.oclc.org/NET/ssnx/ssn#>
PREFIX dgo: <http://www.iiitd.edu.in/~haroonr/ontologies/DGO#>
SELECT distinct *
WHERE {
dgo:DiningRoom rdfs:subClassOf ?property .
?property owl:someValuesFrom ?y.
}