新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   >>中国XML论坛<<     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论Semantic Web(语义Web,语义网或语义万维网, Web 3.0)及相关理论,如:Ontology(本体,本体论), OWL(Web Ontology Langauge,Web本体语言), Description Logic(DL, 描述逻辑),RDFa,Ontology Engineering等。
    [返回] 中文XML论坛 - 专业的XML技术讨论区W3CHINA.ORG讨论区 - Web新技术讨论『 Semantic Web(语义Web)/描述逻辑/本体 』 → [原创]实现将OWL本体文件存储到MySQL数据库 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 21404 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: [原创]实现将OWL本体文件存储到MySQL数据库 举报  打印  推荐  IE收藏夹 
       本主题类别: 经典问答 | Ontology Language | RDF/RDFS    
     dorothyle 美女呀,离线,快来找我吧!
      
      
      等级:大二(研究汇编)
      文章:44
      积分:285
      门派:XML.ORG.CN
      注册:2009/9/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给dorothyle发送一个短消息 把dorothyle加入好友 查看dorothyle的个人资料 搜索dorothyle在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 引用回复这个贴子 回复这个贴子 查看dorothyle的博客楼主
    发贴心情 [原创]实现将OWL本体文件存储到MySQL数据库

    首先配置好开发环境,我采用的是Eclipse + mysql-essential-5.1.51-win32,对于MySQL的JDBC选择的是mysql-connector-java-5.0.8。我把JDBC在D盘的根目录下解压缩,在环境变量中将JDBC的所在地址加入原有的classpath中,然后开始存储本体文件工作。
    1. 利用MySQL创建一个数据库:create database jena;
    2. 打开Eclipse,新建一个Java工程,起名为Persistent。
    3. 新建工程的同时,分别导入Jena包和MySQL的JDBC。
    4. 在工程Persistent\src\目录下新建一个Java文件,名字为Persistent.java;
    5. 开始编写以下代码:
    import java.io.*;
    import java.sql.SQLException;
    import com.hp.hpl.jena.db.*;
    import com.hp.hpl.jena.rdf.model.*;

    public class Persistent {
     public static final String strDriver = "com.mysql.jdbc.Driver";
     public static final String strURL = "jdbc:mysql://localhost:3306/jena";
    // localhost的后面要直接写冒号,再写3306;
     public static final String strUser = "root";
     public static final String strPassword = "root";
     public static final String strDB = "MySQL";
     
     public static void main(String[] args){
      try {
       DBConnection connection = new DBConnection(strURL, strUser, strPassword, strDB);
       // 创建连接时,第四个参数需要指定所用的数据库类型;也就是说strDB的值应该是“MySQL”
       try {
        Class.forName("com.mysql.jdbc.Driver");
        System.out.println("驱动程序已经安装。");
       } catch (ClassNotFoundException e){
        System.out.println("ClassNotFoundException, Driver is not available");
        }
       System.out.println("数据库连接成功。");
       
       // 从此处开始读入一个OWL文件并且存储到数据库中;
      
       ModelMaker maker = ModelFactory.createModelRDBMaker(connection);
    // 使用数据库连接参数创建一个模型制造器
       Model defModel = maker.createModel("Costume");
         // 创建一个默认模型,命名为Costume,因为我要存入的OWL文件名是Costume
       
       FileInputStream read = null;
       try{
        File file = new File("e:/ontologies/BeijingOpera/Costume.owl");
        read = new FileInputStream(file);
       }catch (FileNotFoundException e){
        e.printStackTrace();
        System.out.println("未找到要存储的本体文件,请检查文件地址及名称");
       }
       System.out.println("已将本体文件转换为字节流文件。");
       
       InputStreamReader in = null;
       try {
        in = new InputStreamReader((FileInputStream)read, "UTF-8");
       } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
        System.out.println("不支持上述字符集。");
       }
       System.out.println("已将字节流文件转换为UTF-8编码。");
       
       defModel.read(in,null);
       try {
        in.close();
       } catch (IOException e){
        e.printStackTrace();
        System.out.println("无法关闭字节流文件。");
       }
       System.out.println("已将字节流文件关闭。");
       
       defModel.commit();
       System.out.println("数据转换执行完毕,已将本体文件存入数据库。");
       try{
        connection.close();
       } catch (SQLException e){
        e.printStackTrace();
        System.out.println("文件无法关闭。");
       }
      } catch (RDFRDBException e){
       System.out.println("出现异常");
       }
      System.out.println("已将本体文件持久化到数据库中");
      }
    }
    6. 在代码的编写过程中遇到的第一个问题是,程序执行后总是提示:
    Failure to instantiate DB Driver:jena
    java.lang.ClassNotFoundException: com.hp.hpl.jena.db.impl.Driver_jena
    解决办法:上述提示的意思是无法对指定的数据库文件进行实例化,仔细查看是因为创建数据库连接时的连接语句有辨别是问题,创建数据库的连接语句是:
    DBConnection connection = new DBConnection(strURL, strUser, strPassword, strDB);
    这四个参数分别是指定数据库的URL,用户名称(即安装MySQL时创建的用户名),用户密码,以及所选择的数据库类型,所以最后一个参数应该是“MySQL”,我第一次把这个参数给写成了数据库的名称,所以出现“无法实例化数据库”的提示。

    7. 遇到的第二个问题是:UTF-8字符集的指定总是提示出错,解决办法就是在文件前面加上该文件的类型,即:
    in = new InputStreamReader((FileInputStream)read, "UTF-8");


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/10/21 10:02:00
     
     campbell 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:6
      积分:76
      门派:XML.ORG.CN
      注册:2010/10/9

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给campbell发送一个短消息 把campbell加入好友 查看campbell的个人资料 搜索campbell在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 引用回复这个贴子 回复这个贴子 查看campbell的博客2
    发贴心情 
    你好,我按照你给的方法操作了一下,但有错误,请问是应该如何修改?谢谢!

    Description Resource Path Location Type
    DBConnection cannot be resolved to a type Persistent.java /Persistent/src line 15 Java Problem
    DBConnection cannot be resolved to a type Persistent.java /Persistent/src line 15 Java Problem
    Model cannot be resolved to a type Persistent.java /Persistent/src line 29 Java Problem
    ModelFactory cannot be resolved Persistent.java /Persistent/src line 27 Java Problem
    ModelMaker cannot be resolved to a type Persistent.java /Persistent/src line 27 Java Problem
    RDFRDBException cannot be resolved to a type Persistent.java /Persistent/src line 68 Java Problem

    好像是包引用的问题,但导入的包是没问题的,我的用的是jena-2.6.4-javadoc.jar和
    mysql-connector-java-5.1.15-bin.jar   谢谢!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2011/3/24 3:47:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/12/18 14:42:36

    本主题贴数2,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    46.875ms