我有个问题。
我正在尝试在 Jena TDB 上加载我的 RDF 文件。
我写了这段代码:
public void store(){
String directory = "C:\\tdb";
String source = "C:\\file1.rdf";
String source1 = "C:\\file2.rdf";
Dataset dataset = openTDB(directory);
Model tdb = loadModel(source, dataset);
dataset.addNamedModel("File1", tdb);
Model tdb1 = loadModel(source1, dataset);
dataset.addNamedModel("File2", tdb1);
queryTDB(tdb, dataset);
queryTDB(tdb1, dataset);
tdb.close();
tdb1.close();
dataset.close();
}
public Dataset openTDB(String directory) {
// open TDB dataset
Dataset dataset = TDBFactory.createDataset(directory);
return dataset;
}
public Model loadModel(String source, Dataset dataset) {
Model tdb = dataset.getDefaultModel();
FileManager.get().readModel( tdb, source, "RDF/XML" );
return tdb;
}
特别是,我有两个文件,我想将这些文件加载到 Jena TDB 上。我在互联网上读到我可以使用“addNamedModel”为我的模型添加一个名称。为此,在上面的代码中,我添加了名称“File1”和“File2”。
现在,我想查询这个数据集,我正在尝试编写这段代码:
public void queryTDB(Model tdb, Dataset dataset) {
String queryStr = "SELECT * { ?s ?p ?o }";
Query query = QueryFactory.create(queryStr);
QueryExecution qexec = QueryExecutionFactory.create(query, tdb);
/*Execute the Query*/
ResultSet results = qexec.execSelect();
ResultSetFormatter.out(results) ;
qexec.close();
}
此代码有效,但我想知道如何仅为名为“File1”(或“File2”)的模型获取查询结果。事实上,通过这样编写的查询,我得到了两个模型的结果。
我怎么能意识到呢?