2

我在我的应用程序中使用 dbpedia,并且我将 Jena 用于语义逻辑。

在耶拿,课程是:

模型:一组语句 http://jena.sourceforge.net/javadoc/com/hp/hpl/jena/rdf/model/Model.html 资源: http: //jena.sourceforge.net/javadoc/com/hp /hpl/jena/rdf/model/Resource.html

在 dbpedia 中,资源的 rdf 代码是这样的:例如http://dbpedia.org/resource/Frederick_of_Sweden 变为http://dbpedia.org/data/Frederick_of_Sweden.rdf

如果我打电话:

Model model = maker.createModel( "http://dbpedia.org/data/Frederick_of_Sweden.rdf")

创建了一个名为“http://dbpedia.org/data/Frederick_of_Sweden.rdf”的模型。但我实际上需要将其称为“http://dbpedia.org/resource/Frederick_of_Sweden”,以与 rdf 语句保持一致。如何命名模型?

如果我想浏览图表并到达其他节点,存储这些语句的最佳方式是什么?我是否需要为每个 dbpedia 资源创建一个单独的模型,还是可以将所有语句合并到一个大模型中?

感谢您的任何提示!穆龙

4

1 回答 1

4

我认为您创建模型的方式不会真正影响您下载数据的方式。您可以使用您喜欢的 URI 标识符创建模型。

在这里,我展示了一个示例,该示例可以提供一些想法,说明如何区分从 DBPedia 获取三元组的方式以及将它们存储在后端系统中的方式。

根据您的问题,我假设您正在使用数据库后端,因此我的代码针对的是 Jena 中的那种后端。

import java.sql.SQLException;
import com.hp.hpl.jena.util.FileManager;
import com.hp.hpl.jena.rdf.model.Model;
import com.hp.hpl.jena.rdf.model.SimpleSelector;
import com.hp.hpl.jena.rdf.model.Property;
import com.hp.hpl.jena.rdf.model.RDFNode;
import com.hp.hpl.jena.rdf.model.Literal;
import com.hp.hpl.jena.rdf.model.StmtIterator;
import com.hp.hpl.jena.rdf.model.Statement;
import com.hp.hpl.jena.db.DBConnection;
import com.hp.hpl.jena.rdf.model.ModelMaker;
import com.hp.hpl.jena.rdf.model.ModelFactory;

public class TestJena {

    public static void main(String[] args) throws java.lang.ClassNotFoundException, java.sql.SQLException {
        Class.forName("com.mysql.jdbc.Driver");            

        //The database backend initialization.
        DBConnection connection = new DBConnection(MY_DB, USER, PASS, "mysql");
        ModelMaker dbMaker = ModelFactory.createModelRDBMaker(connection);

        //A file manager to get the triples from the DBPedia revolvable URI. 
        FileManager fManager = FileManager.get();
        fManager.addLocatorURL();
        Model linkedDataModel =
              fManager.loadModel("http://dbpedia.org/data/Frederick_of_Sweden.rdf");


        //Now we copy the in-memory model into our DB backend. 
        //When the model is created you can give it the name that you like.
        Model dbModel = 
              dbMaker.createModel("http://dbpedia.org/resource/Frederick_of_Sweden");

        dbModel.add(linkedDataModel);

        StmtIterator iter = dbModel.listStatements();
        while (iter.hasNext()) {
            Statement stmt = iter.nextStatement();
            System.out.println(stmt);
        }


        linkedDataModel.close();
        dbModel.close();
        connection.close();
}

此示例打印...

[http://dbpedia.org/resource/Frederick_i_of_sweden, http://dbpedia.org/ontology/wikiPageRedirects, http://dbpedia.org/resource/Frederick_of_Sweden]
[http://dbpedia.org/resource/Frederick_I_%28of_Sweden%29, http://dbpedia.org/ontology/wikiPageRedirects, http://dbpedia.org/resource/Frederick_of_Sweden]
[http://dbpedia.org/resource/Frederick_I,_Landgrave_of_Hesse-Kassel, http://dbpedia.org/ontology/wikiPageRedirects, http://dbpedia.org/resource/Frederick_of_Sweden]
[http://dbpedia.org:8890/data/Frederick_of_Sweden.rdf, http://xmlns.com/foaf/0.1/primaryTopic, http://dbpedia.org/resource/Frederick_of_Sweden]
(....)
于 2011-02-16T01:33:54.537 回答