首页 文章

在Openlink Virtuoso中加载和查询默认和命名的RDF图

提问于
浏览
1

我对OpenLink Virtuoso很新,我有一些关于加载RDF图并通过Java和Virtuoso Jena Provider对它们执行SPARQL查询的问题 .

我在运行 Ubuntu 16.04 桌面版的PC上安装了 Virtuoso version 06.01.3127 . 另外,我使用Virtuoso Jena Provider 3和Virtuoso JDBC 4 Driver .

我想运行SPARQL查询调用默认和命名图形,如下所示:

prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
prefix cc: <http://example.org/cc/>
SELECT ?c1 ?sx ?c2 ?m
FROM <http://test.org>
WHERE { ?c1 rdf:type cc:Test1; cc:p11 ?sx.
     ?c2 rdf:type cc:Test2; cc:p21 ?sx; cc:p22 ?m.
     FILTER EXISTS { GRAPH <http://testA.org> {?m cc:p cc:M.} }
}

因此,假设存在默认图形( http://test.org )和一个命名图形( http://testA.org ) .

我尝试使用 VirtDataset 如下:

VirtModel Model1 = VirtModel.openDefaultModel("jdbc:virtuoso://localhost:1111/charset=UTF-8", <usr>, <pass>);
Model1.read(RDF1InputStream, null, "TTL");
VirtModel Model2 = VirtModel.openDatabaseModel("http://testA.org", "jdbc:virtuoso://localhost:1111/charset=UTF-8", <usr>, <pass>);
Model2.read(RDF2InputStream, null, "TTL");
VirtDataset virtDataset = new VirtDataset("jdbc:virtuoso://localhost:1111/charset=UTF-8", <usr>, <pass>);
virtDataset.setDefaultModel(Model1);
virtDataset.addNamedModel("http://testA.org", Model2);

String queryString = "prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
        prefix cc: <http://example.org/cc/>
        SELECT ?c1 ?sx ?c2 ?m
        WHERE { ?c1 rdf:type cc:Test1; cc:p11 ?sx.
         ?c2 rdf:type cc:Test2; cc:p21 ?sx; cc:p22 ?m.
         FILTER EXISTS { GRAPH <http://testA.org> {?m cc:p cc:M.} }
        }";
Query query = QueryFactory.create(queryString);
QueryExecution qe = QueryExecutionFactory.create(query, virtDataset);
ResultSet rs = qe.execSelect();
while (rs.hasNext()) {
    System.out.println(rs.next());
}
qe.close();
virtDataset.close();

但是,它最终会出现以下错误: Model1.read(RDF1InputStream, null, "TTL");

Exception in thread "main" org.apache.jena.shared.JenaException: java.sql.BatchUpdateException: SR185: Undefined procedure DB.DBA.rdf_insert_triple_c.
    at virtuoso.jena.driver.VirtGraph.stopBatchAdd(VirtGraph.java:1090)
    at virtuoso.jena.driver.VirtModel.read(VirtModel.java:273)
    at VirtuosoTest.main(VirtuosoTest.java:45)
Caused by: java.sql.BatchUpdateException: SR185: Undefined procedure DB.DBA.rdf_insert_triple_c.
    at virtuoso.jdbc4.VirtuosoPreparedStatement.throwBatchUpdateException(VirtuosoPreparedStatement.java:520)
    at virtuoso.jdbc4.VirtuosoPreparedStatement.executeBatchUpdate(VirtuosoPreparedStatement.java:156)
    at virtuoso.jdbc4.VirtuosoPreparedStatement.executeBatch(VirtuosoPreparedStatement.java:541)
    at virtuoso.jena.driver.VirtGraph.stopBatchAdd(VirtGraph.java:1083)
    ... 2 more

程序 DB.DBA.rdf_insert_triple_c 是否缺失?我怎样才能解决这个问题?

作为替代方案,我尝试使用 VirtGraph 如下:

VirtGraph virtGraphTest = new VirtGraph("http://test.org", "jdbc:virtuoso://localhost:1111/charset=UTF-8", <usr>, <pass>);
virtGraphTest.read("file://test/test.ttl", "TTL");
virtGraphTest.close();
VirtGraph virtGraphTestA = new VirtGraph("http://testA.org", "jdbc:virtuoso://localhost:1111/charset=UTF-8", <usr>, <pass>);
virtGraphTestA.read("file://test/testA.ttl", "TTL");
virtGraphTestA.close();
VirtGraph virtGraph = new VirtGraph("jdbc:virtuoso://localhost:1111/charset=UTF-8", <usr>, <pass>);

String queryStringTest = " prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
        prefix cc: <http://example.org/cc/>
        SELECT ?c1 ?sx ?c2 ?m
        FROM <http://test.org>
        WHERE { ?c1 rdf:type cc:Test1; cc:p11 ?sx.
         ?c2 rdf:type cc:Test2; cc:p21 ?sx; cc:p22 ?m.
         FILTER EXISTS { GRAPH ?g {?m cc:p cc:M.} FILTER(?g=<http://testA.org>) }
        }";
Query queryTest = QueryFactory.create(queryStringTest);
VirtuosoQueryExecution qet = VirtuosoQueryExecutionFactory.create(queryTest, virtGraph);
ResultSet rst = qet.execSelect();
while (rst.hasNext()) {
    System.out.println(rst.next());
}
qet.close();
virtGraph.close();

这似乎工作正常 .

请注意,在SPARQL查询的 GRAPH 声明中,我使用 GRAPH ?g 然后使用 FILTER (?g=<http://testA.org>) 来指定命名图 .

如果我改为使用 GRAPH <http://testA.org> ,则会解析查询,但根据查询结果,似乎会忽略 GRAPH 声明 .

在Virtuoso的SPARQL查询中调用 GRAPH 的正确方法是什么?

总的来说,我想知道哪个是处理RDF数据集和SPARQL查询在Virtuoso中调用默认和命名RDF图的最佳实践?

我已经在Google上搜索了这些问题,但我还没有看到一个启发性的例子 .

对不起,很长的帖子,谢谢你提前!

1 回答

  • 0

    程序 DB.DBA.rdf_insert_triple_c 内置于Virtuoso服务器中,并且在旧版本的Virtuoso 6.x中不存在(您的版本可以追溯到2013年或更早版本) .

    您可以安装current version Virtuoso server 7.x(强烈推荐),或使用旧版本的Virtuoso Jena提供商用于Virtuoso 6.x.

相关问题