【问题标题】:Jena TDB to store and query using APIJena TDB 使用 API 存储和查询
【发布时间】:2012-06-19 13:15:23
【问题描述】:

我是 Jena-TDB 和 SPARQL 的新手,所以这可能是一个愚蠢的问题。我在 Windows XP 上使用 tdb-0.9.0。

我正在为我的trail_1.rdf 文件创建 TDB 模型。我在这里的理解(如果我错了,请纠正我)是以下代码将读取 TDB 模型中的给定 rdf 文件,并在给定目录D:\Project\Store_DB\data1\tdb 中存储/加载(不确定什么是更好的词)模型:

// open TDB dataset
String directory = "D:\\Project\\Store_DB\\data1\\tdb";
Dataset dataset = TDBFactory.createDataset(directory);

Model tdb = dataset.getDefaultModel();

// read the input file
String source = "D:\\Project\\Store_DB\\tmp\\trail_1.rdf";
FileManager.get().readModel( tdb, source);

tdb.close();
dataset.close();

这种理解正确吗?


根据我的理解,现在模型存储在D:\Project\Store_DB\data1\tdb 目录中,我应该能够在稍后的某个时间点对其运行查询。

所以要在D:\Project\Store_DB\data1\tdb 查询 TDB 存储,我尝试了以下操作,但它什么也没打印:

String directory = "D:\\Project\\Store_DB\\data1\\tdb" ;
Dataset dataset = TDBFactory.createDataset(directory) ;

Iterator<String> graphNames = dataset.listNames();
while (graphNames.hasNext()) {
    String graphName = graphNames.next();
    System.out.println(graphName);
}

我也试过这个,也没有打印任何东西:

    String directory = "D:\\Project\\Store_DB\\data1\\tdb" ;
    Dataset dataset = TDBFactory.createDataset(directory) ;

    String sparqlQueryString = "SELECT (count(*) AS ?count) { ?s ?p ?o }" ;

    Query query = QueryFactory.create(sparqlQueryString) ;
    QueryExecution qexec = QueryExecutionFactory.create(query, dataset) ;
    ResultSet results = qexec.execSelect() ;
    ResultSetFormatter.out(results) ;

我做错了什么?我上面提到的我的理解有什么问题吗?

【问题讨论】:

    标签: java jena


    【解决方案1】:

    对于您问题的第 (i) 部分,是的,您的理解是正确的。

    对于第 (ii) 部分,listNames 没有返回任何结果的原因是因为您没有将数据放入命名图中。特别是,

    Model tdb = dataset.getDefaultModel();
    

    表示您将数据存储到 TDB 的默认图形中,即没有名称的图形。如果您希望 listNames 返回某些内容,请将该行更改为:

    Model tdb = dataset.getNamedGraph( "graph42" );
    

    或类似的东西。当然,您需要在查询数据时按名称引用该图。

    如果您的目标只是测试您是否已成功将数据加载到存储中,请尝试使用命令行工具 bin/tdbdump (Linux) 或 bat\tdbdump.bat (Windows)。

    对于第 (iii) 部分,我在我的系统上尝试了您的代码,指向我的一张 TDB 图像,它的工作方式与预期的一样。所以:要么您使用的 TDB 映像中没有任何数据(使用 tdbdump 测试),要么您实际运行的代码与上面的示例不同。

    【讨论】:

      【解决方案2】:

      我认为您第 1 部分代码中的问题是,您没有提交数据。

      尝试使用此版本的第 1 部分代码:

         String directory = "D:\\Project\\Store_DB\\data1\\tdb";
         Dataset dataset = TDBFactory.createDataset(directory);
      
         Model tdb = dataset.getDefaultModel();
      
         // read the input file
         String source = "D:\\Project\\Store_DB\\tmp\\trail_1.rdf";
         FileManager.get().readModel( tdb, source);
      
         dataset.commit();//INCLUDE THIS STAMEMENT
      
         tdb.close();
         dataset.close();
      

      然后尝试使用您的第 3 部分代码:) ....

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多