【发布时间】: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) ;
我做错了什么?我上面提到的我的理解有什么问题吗?
【问题讨论】: