首页 文章

如何使用 Sesame 查询 SPARQL 端点(如 DBPedia)?

提问于
浏览
2

我使用 Sesame triplestore 来存储我的数据。当我尝试使用带有 Sesame 的查询接口和外部资源(如 dbpedia)时,我没有得到任何结果。在添加所有必需的前缀后,此查询返回带有 snorql 但不返回 Sesame 的结果:

select ?routes where {
  dbpedia:Polio_vaccine dbpprop:routesOfAdministration ?routes
}

我需要改变什么?

1 回答

  • 6

    您可以使用 Sesame 以各种方式查询任何 SPARQL 端点,包括 DBPedia,可以通过 Sesame Workbench 以编程方式或手动方式查询。

    使用 Workbench

    使用 Sesame Workbench 工具,您可以通过为该端点创建存储库代理来查询 DBPedia(或任何公共 SPARQL 端点),如下所示:

    • 选择“新建存储库”,然后在存储库类型菜单中选择“SPARQL 端点代理”。为代理提供标识符和可选的标题,然后单击“下一步”。
      创建 sparql 端点代理

    • 填写查询端点的 SPARQL 端点 URL。对于公共 DBPedia 服务器,这应该是http://dbpedia.org/sparql
      在此输入图像描述

    • 单击“创建”完成。

    设置完成后,您可以在“查询”菜单中查询:

    Sesame Workbench SPARQL 查询编辑器

    结果:

    在此输入图像描述

    程序化访问

    您只需创建一个连接到 DBPedia 端点的SPARQLRepository对象:

    Repository repo = new SPARQLRepository("http://dbpedia.org/sparql");
    repo.initialize();
    

    完成后,您可以使用它来执行 SPARQL 查询,就像在任何其他 Sesame 存储库上一样:

    RepositoryConnection conn = repo.getConnection();
    try {
        StringBuilder qb = new StringBuilder();
        qb.append("PREFIX dbpedia: <http://dbpedia.org/resource/> \n");    
        qb.append("PREFIX dbpprop: <http://dbpedia.org/property/> \n");
        qb.append("SELECT ?routes \n");
        qb.append("WHERE { dbpedia:Polio_vaccine dbpprop:routesOfAdministration ?routes } \n");
    
        TupleQueryResult result = 
             conn.prepareTupleQuery(QueryLanguage.SPARQL, qb.toString()).evaluate(); 
    
        while(result.hasNext()) {
             BindingSet bs = result.next();
             Value route = bs.getValue("routes");
             System.out.println("route = " + route.stringValue());
        }
     }
     finally {
        conn.close();
     }
    

相关问题