2012-06-19 35 views
5

我对Jena-TDB和SPARQL都是新手,所以这可能是一个愚蠢的问题。我在Windows XP上使用tdb-0.9.0。Jena TDB使用API​​存储和查询

我正在为我的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目录,我应该能够在某个时间点在其上运行的查询。

所以查询TDB商店在D:\Project\Store_DB\data1\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) ; 

我在做什么不正确?我的理解有什么不妥之处?

回答

3

对于问题的第(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部分的代码:) ....