繁体   English   中英

Jena TDB使用API​​存储和查询

[英]Jena TDB to store and query using API

我是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) ;

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

对于您的问题的第(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测试),或者您实际运行的代码与上述示例不同。

我认为您的第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部分的代码试试:) ....

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM