首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用API存储和查询Jena TDB

使用API存储和查询Jena TDB
EN

Stack Overflow用户
提问于 2012-06-19 13:15:23
回答 2查看 7.3K关注 0票数 6

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

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

代码语言:javascript
复制
// 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,我尝试了如下方法,但它没有打印任何内容:

代码语言:javascript
复制
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);
}

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

代码语言:javascript
复制
    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) ;

我做错什么了?我上述的理解有什么问题吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-06-20 09:07:27

关于你问题的第(一)部分,是的,你的理解是正确的。

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

代码语言:javascript
复制
Model tdb = dataset.getDefaultModel();

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

代码语言:javascript
复制
Model tdb = dataset.getNamedGraph( "graph42" );

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

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

对于第(iii)部分,我在我的系统上尝试了您的代码,指向我的TDB映像之一,它的工作就像人们所期望的那样。所以:您使用的TDB映像中没有任何数据(使用tdbdump进行测试),或者您实际运行的代码与上面的示例不同。

票数 5
EN

Stack Overflow用户

发布于 2014-02-27 12:03:23

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

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

代码语言:javascript
复制
   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部分代码:) .

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11101757

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档