我是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();
Run Code Online (Sandbox Code Playgroud)
这种理解是否正确?
根据我的理解,因为现在模型存储在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);
}
Run Code Online (Sandbox Code Playgroud)
我也尝试了这个,也没有打印任何东西:
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) ;
Run Code Online (Sandbox Code Playgroud)
我做错了什么?我上面提到的理解有什么不对吗?
对于您问题的 (i) 部分,是的,您的理解是正确的。
对于第 (ii) 部分,listNames不返回任何结果的原因是您尚未将数据放入命名图中。特别是,
Model tdb = dataset.getDefaultModel();
Run Code Online (Sandbox Code Playgroud)
意味着您将数据存储到 TDB 的默认图形中,即没有名称的图形。如果您想listNames返回某些内容,请将该行更改为:
Model tdb = dataset.getNamedGraph( "graph42" );
Run Code Online (Sandbox Code Playgroud)
或类似的东西。当然,您随后需要在查询数据时按名称引用该图。
如果您的目标只是测试您是否已成功将数据加载到存储中,请尝试使用命令行工具bin/tdbdump(Linux) 或bat\tdbdump.bat(Windows)。
对于第 (iii) 部分,我在我的系统上尝试了您的代码,指向我的一个 TDB 图像,它的工作原理与人们预期的一样。所以:要么您使用的 TDB 图像中没有任何数据(使用 tdbdump 测试),要么您实际运行的代码与上面的示例不同。