Jena Fuseki 101
前言
正如其承诺的那样
Expose your triples as a SPARQL end-point accessible over HTTP. Fuseki provides REST-style interaction with your RDF data.
Fuseki提供了可通过HTTP访问SPARQL终端,那么它应该实现RDF存储、CRUD等事务性操作、同时兼容W3C SPARQL 1.1建议(http://www.w3.org/TR/2012/PR-sparql11-overview-20121108/)。
本文记录Fuseki的启动、如何导入数据、在Fuseki中执行SPARQL查询和更新,以及如何以编程方式实现Fuseki中SPARQL查询和更新。
内容
1 运行Fuseki
2 准备数据
3 执行SPARQL查询
4 执行SPARQL更新
5 编程方式实现SPARQL查询和更新
6 待考察问题
1 运行Fuseki
版本jena-fuseki-1.0.1
解压到目录${FUSEKI},在该目录下运行
java -jar fuseki-server.jar –config=config-tdb.ttl
运行输出:

2 准备数据
数据仍用Jena TDB API without Assembler(http://www.cnblogs.com/zhoujiagen/p/3647783.html)中的graph.owl
Fuseki Web管理界面登录(http://localhost:3030)

点击Control Panel进入Fuseki服务管理,
选择数据集/data,进入Fuseki Query界面:

选择文件(graph.owl)上传。
3 执行SPARQL查询
在SPARQL Qeury中输入查询语句
PREFIX rdf: -rdf-syntax-ns#>
PREFIX owl: /owl#>
PREFIX xsd: /XMLSchema#>
PREFIX rdfs: /rdf-schema#>
PREFIX graph: <http://www.nosql.com/graph#>
SELECT ?friend
WHERE { graph:Martin graph:friend ?friend }
点击Get Results,

4 执行SPARQL更新
在SPARQL Qeury中输入更新语句
PREFIX graph: <http://www.nosql.com/graph#>
INSERT DATA
{
graph:Martin graph:friend graph:ZhouJiaGen .
}
点击Perform update后,再次执行查询:

5 编程方式实现SPARQL查询和更新
下面以自说明的代码说明如何通过编程方式执行Fuseki中RDF数据的查询和更新
package arq;
import static util.Constants.NEWLINE;
import org.apache.jena.fuseki.http.UpdateRemote;
import com.hp.hpl.jena.query.QueryExecution;
import com.hp.hpl.jena.query.QueryExecutionFactory;
import com.hp.hpl.jena.query.QuerySolution;
import com.hp.hpl.jena.query.ResultSet;
import com.hp.hpl.jena.rdf.model.RDFNode;
import com.hp.hpl.jena.update.UpdateFactory;
import com.hp.hpl.jena.update.UpdateRequest;
public class SPARQLUsingFuseki {
static final String PREFIX = "graph";
static final String NS = "http://www.nosql.com/graph#";
public static void main(String[] args) {
sparqlUpdate();
}
@SuppressWarnings("deprecation")
static void sparqlUpdate() {
String update = "";
StringBuilder sb = new StringBuilder();
sb.append("PREFIX graph: <http://www.nosql.com/graph#>").append(NEWLINE).append(" INSERT DATA").append(NEWLINE).append("{").append(NEWLINE)
.append("graph:Martin graph:friend graph:ZhouJiaGen2 .").append(NEWLINE).append("}");
update = sb.toString();
UpdateRequest request = UpdateFactory.create(update);
UpdateRemote.execute(request, "http://localhost:3030/data/update");
}
// / output:
// http://www.nosql.com/graph#Pramod
static void sparqlQuery() {
// 准备SPARQL查询
StringBuilder sb = new StringBuilder();
sb.append("PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>").append(NEWLINE).append("PREFIX owl: <http://www.w3.org/2002/07/owl#>")
.append(NEWLINE).append("PREFIX xsd: <http://www.w3.org/2001/XMLSchema#>").append(NEWLINE)
.append("PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>").append(NEWLINE).append("PREFIX foaf: <http://xmlns.com/foaf/0.1/>")
.append(NEWLINE).append("PREFIX myfoaf: <http://blog.sina.com.cn/zhoujiagenontology/helloworld.owl#>").append(NEWLINE)
.append("PREFIX " + PREFIX + ": " + "<" + NS + ">").append(NEWLINE);
sb.append("SELECT ?friend WHERE { graph:Martin graph:friend ?friend }");
String service = "http://localhost:3030/data/query";// http://localhost:3030/<<dataset>>/query
String query = sb.toString();
QueryExecution queryExecution = QueryExecutionFactory.sparqlService(service, query);
sparqlHelp(queryExecution, "?friend");
}
static void sparqlHelp(QueryExecution queryExecution, String valueLabel) {
ResultSet rs = queryExecution.execSelect();
while (rs.hasNext()) {
QuerySolution qs = rs.nextSolution();
RDFNode name = qs.get(valueLabel);
if (name != null) {
System.out.println(name.toString());
} else {
System.out.println("Not found!");
}
}
queryExecution.close();
}
}
6 待考察问题
(1) 服务器和数据集的配置方法
(2) 如何将查询出的RDF数据与推理机结合
一种简单的思路是直接将推理后的结果存入Fuseki数据集,但这种方式无法区分断言数据和推理后数据;
另一种方法还是将Schema与数据分开,推理只对这部分查询出来的数据执行。
(3) SPARQL查询语言的语法和用例
Jena Fuseki 101的更多相关文章
- python使用rdflib创建rdf,在jena fuseki上执行SPARQL查询
建立并启动jena fuseki服务 参考:https://www.cnblogs.com/bincoding/p/11223372.html 使用rdflib创建rdf文件 import rdfli ...
- 搭建Jena Fuseki并执行SPARQL查询
1. 下载Jena Fuseki:http://jena.apache.org/download/index.cgi 2. 运行服务 windows解压后双击fuseki-server.bat lin ...
- Apache Jena Fuseki使用
下载Apache Jena Fuseki 先从apache官网下载fuseki压缩包.然后解压到目标文件夹. apache官网:http://jena.apache.org/download/ 这里我 ...
- Jena Fuseki 102
Version Fuseki v1 Fuseki v2 since Jena 2.13.0 Both v1 and v2 are active and maintained.[2015/06/29] ...
- Jena TDB 101 Java API without Assembler
Update on 2015/05/12 ongoing tutorials site on https://github.com/zhoujiagen/semanticWebTutorialUsin ...
- Jena Fuseki安装完成后不能添加数据库
问题描述:安装Jena成功后可以进入管理页面,无法通过界面选择和查询数据 解决方案: 进入 apache-jena-fuseki-3.12.0\run 修改 shiro.ini 配置文件 注释 /$/ ...
- Jena+fuseki
1.下载apache-jena-3.1.0.tar.gz,这个可以将ttl三元组文件或者xml文件加载 进入bin目录,执行./tdbloader2 --loc /path/for/database ...
- Outline of Apache Jena Notes
1 description 这篇是语义网应用框架Apache Jena学习记录的索引. 初始动机见Apache Jena - A Bootstrap 2 Content 内容组织基本上遵循Jena首页 ...
- Jena TDB 102
1 Introduction TDB is a RDF storage of Jena. official guarantees and limitations TDB support full ra ...
随机推荐
- C++库汇总
C++库汇总 C++类库介绍再次体现了C++保持核心语言的效率同时大力发展应用库的发展趋势!!在C++中,库的地位是非常高的.C++之父 Bjarne Stroustrup先生多次表示了设计库来扩充功 ...
- Hadoop简介
原来:计算效率低 现在:成本降低,能用PC机,就不用大型机和高端存储了:软件容错硬件故障视为常态,通过软件保证可靠性:简化并行分布式计算,无需控制节点同步和数据交换,但是谷歌只发表了相关技术论文,没有 ...
- MYSQL添加新用户 MYSQL为用户创建数据库 MYSQL为新用户分配权限
1.新建用户 //登录MYSQL @>mysql -u root -p @>密码 //创建用户 mysql> insert into mysql.user(Host,User,Pas ...
- centos7 安装webmin
一 下载webmin软件包 wget http://prdownloads.sourceforge.net/webadmin/webmin-1.791-1.noarch.rpm 二 安装perl环境 ...
- centos7 Nexus maven私有仓库
cd /home wget http://www.sonatype.org/downloads/nexus-latest-bundle.tar.gz mkdir nexus tar zxvf nexu ...
- Android 签名工具 shell脚本
signApk.sh #!/bin/bash #$1 signed and unaligned apk #$2 unsigned apk #$3 aligned apk #./signApk.sh t ...
- 讲解Python中的递归函数
本文的最重要的收获在于:尾递归是指,在函数返回的时候,调用自身本身,并且,return语句不能包含表达式. 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. 举个例 ...
- ElasticSearch学习问题记录——nested查询不到数据
通过代码创建了索引名称为demoindex,索引类型为school,以下是索引类型的数据映射结构: { "state": "open", "setti ...
- SQL Server显式事务与隐式事务
事务是单个的工作单元.如果某一事务成功,则在该事务中进行的所有数据修改均会提交,成为数据库中的永久组成部分.如果事务遇到错误且必须取消或回滚,则所有数据库修改均被清除. SQL Server中有一下几 ...
- 关于Jedis连接redis出现问题
环境说明: redis服务器系统:ubuntu ip 192.168.10.9 port 6379 两台电脑:一个作为专门的服务器,一个是开发环境,以下一顿操作皆基于开发环境. 就这样的简单的代码连接 ...