第三步 用Jena自定义完成数据库到RDF的映射
2013年10月17日 8:53:27
这一步用Jena编程,终于能做点有技术含量的事情了。这个工作计划本周内完成,下周一好给老师一个交待。
目标:把现有数据库(mysql)中的数据,自定义地映射成为RDF格式。
 
1. 先写一小段代码,解决java执行脚本的问题
        String cmd = "sh /opt/D2RServer/d2rq-0.8.1/project/hello_java_shell";
        Runtime run = Runtime.getRuntime();
        String result = "";
        try {
            Process p = run.exec(cmd);
            BufferedInputStream in = new BufferedInputStream(p.getInputStream());
            BufferedReader br = new BufferedReader(new InputStreamReader(in));
            String lineStr;
            while ((lineStr = br.readLine()) != null) {
                result += lineStr;
            }
            br.close();
            in.close();
        } catch (Exception e) {
            e.printStackTrace();
        }

System.out.println(result);

 
2. 把上面代码中的cmd改为
        String cmd = "/opt/D2RServer/d2rq-0.8.1/generate-mapping -u root -p asdfasdf -d com.mysql.jdbc.Driver -o /opt/D2RServer/d2rq-0.8.1/aniuer.n3 jdbc:mysql://localhost/radar";
即执行了generate-mapping命令,把数据库的内容映射为.n3的文件。
2013年10月19日 16:17:15
经过两天的纠结,困于n3文件无法存储到mysql中,原因是n3文件就是一个文本文件,不符合XML语法,所以一直没有起色。后来才发现D2RQ还有个工具叫dump,还是这个比较猛,能够把数据映射成为正经的rdf文件。所以上面的代码改为
        String cmd = "/opt/D2RServer/d2rq-0.8.1/dump-rdf -u root -p asdfasdf -f RDF/XML-ABBREV -o /opt/D2RServer/d2rq-0.8.1/project/aniuer2.rdf jdbc:mysql://localhost:3306/Weapon";
 
3. 将生成的rdf文件存储到mysql中
目前的问题是,我可以生成rdf文件(虽然这个文件还不完善,以后在映射的阶段调整),但这个文件生成之后,
(1)我无法实例化这些数据到数据库中
(2)我无法通过这个视图查询数据。
 
2013年10月20日 7:51:42
拟采用的办法:
    一是:把jena的版本回归到2.5之前的版本,其中会有com.hp.jena.db.*的类。
    二是:采用新jena版本中的sdb包,这个包究竟是不是上面的替代,还不知道。
 
哥痛定思痛。。。还是用老版本的jena吧,先入上门,以后再改进吧,不纠结这个问题了。
 
2013年10月20日 10:10:07
采用了2.6之后,网上的程序可以运行了。目前的问题是,没有修改映射文件,基础URI没有设置,导致在映射到数据库的过程中,报出这个错。
现在eclipse里面是两个jena的工程,一个是2.6.4,一个是d2rq中的2.7.0。同时进行,用d2rq做映射,用jena2.6来做mysql的存储。
a. 把数据库的数据映射成ttl文件。
b. 把ttl文件dump成为指定的rdf文件。
c. 把rdf文件存储到mysql中。
 
目前有点问题,报错说我没有设置主键,我重新选择了数据库MyDataBase,只有一个表Connection。
输入命令alter table Connection ADD CONSTRAINT PK_Connection PRIMARY KEY(ID),增加了主键。
 
现编程进行两具文件的映射,发现在dump过程中,命令行可以实现,而eclipse中不能实现,还是权限的问题。这个问题的解决竟然是在终端运行eclipse即可,姑且这样吧。
这样还是没解决,先不解决了。在终端运行吧。
 
2013年10月20日 22:30:57
基本上映射成功了,文件还是读不太懂。看来dump还是要学习一下的。
 
2013年10月21日 20:42:54
发现dump后的文件并不标准,我还是应该学习一下,d2rq的dump的具体用法。
 
这一步从格式上讲基本完成,下一步研究定制的映射。
 
有需要交流的可以加QQ: 1q7q1q5q3q6q0q1q8(去掉中间的q)。
 
 

第三步 用Jena自定义完成数据库到RDF的映射的更多相关文章

  1. Linux学习第三步(Centos7安装mysql5.7数据库)

    版本:mysql-5.7.16-1.el7.x86_64.rpm-bundle.tar 前言:在linux下安装mysql不如windows下面那么简单,但是也不是很难.本文向大家讲解了如何在Cent ...

  2. 10分钟系列:NetCore3.1+EFCore三步快速完成数据库交互

    前言 做程序开发,不管是什么语言什么数据库,其中的ORM(对象关系映射)是必不可少的,但是不管选择哪一种ORM,都需要了解其中的运行机制,配置帮助类等等. 所以很多ORM都开始进行升级封装,我们只需要 ...

  3. Spring Boot Starter自定义实现三步曲

    实现自定义的spring boot starter,只需要三步: 1.一个Bean 2.一个自动配置类 3.一个META-INF/spring.factories配置文件 下面用代码演示这三步. 项目 ...

  4. Membership三步曲之入门篇 - Membership基础示例

    Membership 三步曲之入门篇 - Membership基础示例 Membership三步曲之入门篇 -  Membership基础示例 Membership三步曲之进阶篇 -  深入剖析Pro ...

  5. 轻松三步教你配置Oracle—windows环境

    最近笔者在学习Oracle的时候,虽然度过了大家所说的安装难题,但是又遇到了一系列的问题,经过多方求教才知道原来是自己仅仅是安装了Oracle,却没有在环境变量中进行相应的配置.笔者也像大家遇到问题时 ...

  6. [转]Membership三步曲之入门篇 - Membership基础示例

    本文转自:http://www.cnblogs.com/jesse2013/p/membership.html Membership三步曲之入门篇 - Membership基础示例   Members ...

  7. 单点登录CAS使用记(三):实现自定义验证用户登录

    问题: CAS自带的用户验证逻辑太过简单,如何像正常网站一样,通过验证DB中的用户数据,来验证用户以及密码的合法性呢? 方案1:CAS默认的JDBC扩展方案: CAS自带了两种简单的通过JDBC方式验 ...

  8. ASP.NET 安全系列 Membership三步曲之入门篇 - Jesse Liu

    Membership 三步曲 ASP.NET 安全系列 Membership三步曲之入门篇 ASP.NET 安全系列 Membership三步曲之进阶篇 ASP.NET 安全系列 Membership ...

  9. mongodb安装和配置三步走

    最近在重新学习node,所以和同事一起搞了个模仿新浪微博的项目,项目刚开始,所以其他的东西就暂时先不提.这里介绍下mongodb的安装.直接搜索可以看到很多介绍,但是我第一次是失败了,不过看了好几个还 ...

随机推荐

  1. java线程池的使用与详解

    java线程池的使用与详解 [转载]本文转载自两篇博文:  1.Java并发编程:线程池的使用:http://www.cnblogs.com/dolphin0520/p/3932921.html   ...

  2. [JavaScript] 初中级Javascript程序员必修学习目录

    很多人总感觉javascript无法入门,笔者在这里写一下自己的学习过程,以及个人认 为的最佳看书过程,只要各位能按照本人所说步骤走下去,不用很长时间,坚持 个3个月,你的js层级会提高一个档次,无他 ...

  3. [XJOI NOI2015模拟题13] B 最小公倍数 【找规律】

    题目链接:XJOI - NOI2015-13 - B 题目分析 通过神奇的观察+打表+猜测,有以下规律和性质: 1) 删除的 n 个数就是 1~n. 2) 当 c = 2 时,如果 n + 1 是偶数 ...

  4. Winform datagridview相关操作

    datagridview显示行号的2种方法: 方法一: 网上最常见的做法是用DataGridView的RowPostPaint事件在RowHeaderCell中绘制行号: privatevoiddat ...

  5. ASP.net Application及Session 的start end 方法总结

    经过几天的摸索,试验,今天终于可以将Application及Session对象的Start和End方法做下总结了. Application_start: 第一个访问网站的用户会触发该方法. 通常会在该 ...

  6. lr11 BUG?Failed to send data by channels - post message failed.

    问题描述   : http协议,场景运行一会之后,报错! erro信息: Failed to send data by channels - post message failed. 解决方法 :ht ...

  7. 简单讨论数据类型(byte)强制转化后的数值变化规律

    package com.wangzhu.datatype; /** * Java基本数据类型练习 * * @ClassName: DataTypes * @Description: TODO * @a ...

  8. Universal Asynchronous Receiver/Transmitter

    USART簡介與特性 NRZ標準資料格式(Mark/Space) 半雙工/全雙工 Synchronous 同步傳輸 CLOCK SKEW Asynchronous 非同步傳輸 半/全雙工.同步/非同步 ...

  9. [Quick-x]制作新手引导高亮区域方法之一:混合模式

    demo下载:https://github.com/chenquanjun/Quick-x-HighlightArea 1.混合模式 (1)首先创建一个全屏的CCRenderTexture实例 这里使 ...

  10. jdk1.7升级到jdk1.8后出错: [ERROR] javadoc: warning - Multiple sources of package comments found for package

    from: http://blog.joda.org/2014/02/turning-off-doclint-in-jdk-8-javadoc.html [ERROR] javadoc: warnin ...