双数据类型不适用于 RDF 星型查询
Double data type not working with RDF star query
Apache Jena 无法查询其中具有双精度数据类型的 RDF 星型三元组。这是 Jena 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
?
注意:您可能认为我没有使用最佳方式进行插入。但是,这是由于代码中的其他要求,可以通过此途径重现问题。
它适用于 Jena 4.0.0。
在 3.17.0 中 - SPARQL 在使用索引方面更像原始的 RDF*。
因此,非规范术语映射会导致问题。
尝试 "1.0e0"^^xsd:double
或 v 4.x.x.
的词法形式
Apache Jena 无法查询其中具有双精度数据类型的 RDF 星型三元组。这是 Jena 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
?
注意:您可能认为我没有使用最佳方式进行插入。但是,这是由于代码中的其他要求,可以通过此途径重现问题。
它适用于 Jena 4.0.0。
在 3.17.0 中 - SPARQL 在使用索引方面更像原始的 RDF*。
因此,非规范术语映射会导致问题。
尝试 "1.0e0"^^xsd:double
或 v 4.x.x.