Sparql查询没有显示结果

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.

Art*_*mis 5

我想您忘记了如何在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)