Reasoner в виртуальной программе Jena - PullRequest
1 голос
/ 08 мая 2019

Я использую Virtuoso Jena Provider для запроса моего графика, который загружен на Virtuoso, но я также хочу добавить обоснование в свои запросы.

Я пробовал этот код, но я получаю сообщение об ошибке на .execSelect();line

Exception in thread "main" java.lang.NullPointerException
    at mypackage.Main.main(Main.java:49)

Вот код, который я пробовал до сих пор.

VirtGraph vg = new VirtGraph(graph, url, username, password);
VirtModel model = new VirtModel(vg);
InfModel ont = ModelFactory.createInfModel(ReasonerRegistry.getOWLReasoner(), model);
Query sparql = QueryFactory.create("PREFIX sosa: <http://www.w3.org/ns/sosa/>\r\n" + 
                "PREFIX ex: <http://example.org/data/>\r\n" + 
                "SELECT ?s ?o FROM <http://147.27.60.65/sensorOntology> WHERE {?s sosa:isHostedBy ?o}");
QueryExecution vqe = VirtuosoQueryExecutionFactory.create(sparql, ont);
ResultSet results = vqe.execSelect();

Как правильно добавить аргумент в мой график и как я могу запросить результирующий набор?

Вот версии, которые я использую: Jena: 3.1 JDBC: 4 Virtuoso: 6

EDIT Я установил пеллетный разум из https://github.com/stardog-union/pellet, но я могуправильно вывести только файл .owl, хранящийся на моем компьютере и загруженный на Jena, но я все еще не могу вывести тот же файл, загруженный как виртуозный график.

1 Ответ

0 голосов
/ 09 мая 2019

VirtuosoQueryExecutionFactory может работать только с VirtGraph / VirtModel источником данных.

Вы должны использовать Jena Query Engine, если вы хотите выполнять запросы к InfModel источнику данных.

Правильный пример приведен в Virtuoso Jena Example14 => in public static void test4() { ... }

код от test4()

...
    public static void exec_select(String header, Model m, String query) {
        String h = header==null?"":header;
        System.out.println("===========["+h+"]==========");
        System.out.println("Exec: "+ query);
        Query jquery = QueryFactory.create(query) ;
        QueryExecution qexec = QueryExecutionFactory.create(jquery, m) ;
        ResultSet results =  qexec.execSelect();
        ResultSetFormatter.out(System.out, results, jquery);
        qexec.close();
        System.out.println("============================\n");

    }

...

    public static void test4() {
        try {
            System.out.println("--------------- TEST 4 -------------------");
            VirtModel vdata = VirtModel.openDatabaseModel("test:inf4", URL, uid, pwd);
            vdata.removeAll();

            String NS = PrintUtil.egNS;
            Resource c1 = vdata.createResource(NS + "C1");
            Resource c2 = vdata.createResource(NS + "C2");
            Resource c3 = vdata.createResource(NS + "C3");
            vdata.add(c2, RDFS.subClassOf, c3);
            vdata.add(c1, RDFS.subClassOf, c2);
            OntModel om = ModelFactory.createOntologyModel(OntModelSpec.RDFS_MEM_RDFS_INF, vdata);

            exec_select("Data in DB", vdata, "select * where {?s ?p ?o}");

            exec_select("Data in Ontology Model", om, "select * where {?s ?p ?o}");

            exec_select("Data in Ontology", om, "select * where {<"+c1+"> <"+RDFS.subClassOf+"> ?o}");

        } catch (Exception e) {
            System.out.println("ERROR Test Failed.");
            e.printStackTrace();
        }
    }

...