0

Apache Jena 无法查询其中包含双精度数据类型的 RDF 星形三元组。这是耶拿 3.17 问题的重现代码(它也可以在其他版本上重现)。

Dataset dataset = TDB2Factory.createDataset();
Model tempModel = ModelFactory.createDefaultModel();
StringReader reader = new StringReader("@prefix : <http://ex#> "
                                     + "@prefix xsd: <http://www.w3.org/2001/XMLSchema#> "
                                     + ":rk :val \"1.0\"^^xsd:double ."
                                     + "<<:rk :val \"1.0\"^^xsd:double>> :p_key 1");
RDFDataMgr.read(tempModel, reader, null, Lang.TURTLE);

dataset.begin(TxnType.WRITE);
Graph repositoryGraph = dataset.getNamedModel("RAW_MODEL").getGraph();
StmtIterator it = tempModel.listStatements();
while(it.hasNext()) {
    repositoryGraph.add(it.nextStatement().asTriple());
}
dataset.commit()
dataset.end()

现在在查询期间,我正在使用以下代码。

dataset.begin(TxnType.READ);
Query query = QueryFactory.create("SELECT ?s ?o ?id WHERE {"
                                + "<<?s <http://ex#val> ?o>> <http://ex#p_key> ?id"
                                + "}");
try (QueryExecution exec = QueryExecutionFactory.create(query, dataset.getUnionModel())) {
    ResultSet result = exec.execSelect();
    while (result.hasNext()) {
        System.out.println(result.next().toString());
    }
}
dataset.end()

上述查询未能获取任何结果。但是,如果我只是替换 xsd:doublexsd:floatxsd:decimal获取结果。因此,我正在寻求帮助以了解导致此问题的原因是什么xsd:double

注意:您可能认为我没有使用最优化的方式进行插入。但是,这是由于代码中的其他要求,并且可以通过此途径重现问题。

4

1 回答 1

2

它适用于耶拿 4.0.0。

在 3.17.0 中 - SPARQL 在使用索引方面更像原始 RDF*。

因此,非规范术语映射会导致问题。

"1.0e0"^^xsd:double尝试or v 4.xx的词汇形式

于 2021-05-30T17:14:00.620 回答