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:double
为xsd:float
或xsd:decimal
获取结果。因此,我正在寻求帮助以了解导致此问题的原因是什么xsd:double
?
注意:您可能认为我没有使用最优化的方式进行插入。但是,这是由于代码中的其他要求,并且可以通过此途径重现问题。