Har*_*hid 2 rdf owl ontology sparql jena
我有一个本体(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();
Run Code Online (Sandbox Code Playgroud)
获得的输出是:

我知道hasProperty对象关系存在于所述本体中.此外,DiningRoom的可能属性应返回Illuminance,Temperature,Co2Content,AbsoluteHumidity.
我想您忘记了如何在OWL中定义属性.你定义了:
Class: DiningRoom subClassOf: hasProperty some AbsoluteHumidity
Run Code Online (Sandbox Code Playgroud)
因此,您需要编写更复杂的查询:
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.
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
79 次 |
| 最近记录: |