如何在 Jena TDB 数据集中保留名称空间前缀?

How to preserve namespace prefixes in a Jena TDB dataset?

我正在使用 Jena TDB (1.1.1) 来存储一组命名图。一切正常,但每当我从数据集中检索命名图时,所有命名空间前缀信息都会丢失。有没有办法在原始 RDF 图中保留名称空间前缀。

以下代码片段显示了该问题。

@Test
public void testPreserveNsPrefixes(){

    String modelText = "@prefix ro:    <http://purl.org/wf4ever/ro#> ." +
            "@prefix ore:   <http://www.openarchives.org/ore/terms/> ." +
            "@prefix ldp:   <http://www.w3.org/ns/ldp#> ." +
            "<http://example.org/ro> a ore:Aggregation , ro:ResearchObject , ldp:DirectContainer .\n" ;

    // Build the RDF graph
    InputStream stream = new ByteArrayInputStream(modelText.getBytes(StandardCharsets.UTF_8));
    Model model = ModelFactory.createDefaultModel();
    model.read(stream, null, "TURTLE");
    System.out.println("NS prefix count: " + model.getNsPrefixMap().size());

    //Create a dataset
    Dataset dataset = TDBFactory.createDataset("test");

    // Add the RDF graph to the dataset
    dataset.begin(ReadWrite.WRITE) ;
    try {
        dataset.addNamedModel("http://example.org/ro", model);
        dataset.commit() ;
    } finally {
        dataset.end() ;
    }

    //Read the RDF graph again
    dataset.begin(ReadWrite.READ);
    try{
        Model model2 = dataset.getNamedModel("http://example.org/ro");
        model2.write(System.out, "TURTLE");
        System.out.println("NS prefix count: " + model2.getNsPrefixMap().size());
    } finally {
        dataset.end();
    }
}

这个输出是:

    NS prefix count: 3
    <http://example.org/ro>
        a       <http://www.w3.org/ns/ldp#DirectContainer> ,
                <http://purl.org/wf4ever/ro#ResearchObject> ,
                <http://www.openarchives.org/ore/terms/Aggregation> .
    NS prefix count: 0

我认为与 this question 有关,但我不认为它是完全相同的。

为了避免评论被删除后答案丢失,AndyS that this was discussed on the Jena user's mailing list, and resolved in issue JENA-860, Adding a graph does not add prefixes