新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   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数据库过程中“创建一个模型制造器”时抛异常[求助] 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 59390 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 将OWL本体文件存储到MySQL数据库过程中“创建一个模型制造器”时抛异常[求助] 举报  打印  推荐  IE收藏夹 
       本主题类别: Ontology Language | RDF/RDFS    
     baiz_2010 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:6
      积分:88
      门派:XML.ORG.CN
      注册:2010/11/29

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给baiz_2010发送一个短消息 把baiz_2010加入好友 查看baiz_2010的个人资料 搜索baiz_2010在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 引用回复这个贴子 回复这个贴子 查看baiz_2010的博客楼主
    发贴心情 将OWL本体文件存储到MySQL数据库过程中“创建一个模型制造器”时抛异常[求助]


    根据dorothyle前辈发的《[原创]实现将OWL本体文件存储到MySQL数据库》这个帖子,做了个测试,

    用的是mysql。

    把其中相应的参数修改完后,run的时候,在  
    Model defModel = maker.createModel("Animal"); 这句的时候报错。

    错误为:
    [color=#FF0000]
    驱动程序已经安装。
    数据库连接成功。
    SLF4J: Class path contains multiple SLF4J bindings.
    SLF4J: Found binding in [jar:file:/E:/eclipse/owl_workspace/owlWebTest/WebContent/WEB-INF/lib/slf4j-log4j12-1.5.10.jar!/org/slf4j/impl/StaticLoggerBinder.class]
    SLF4J: Found binding in [jar:file:/E:/eclipse/owl_workspace/owlWebTest/WebContent/WEB-INF/lib/slf4j-log4j12-1.5.8.jar!/org/slf4j/impl/StaticLoggerBinder.class]
    SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
    Exception in thread "main" com.hp.hpl.jena.shared.JenaException: The database appears to be unformatted or corrupted - could not find value
    for "long object length" in Jena system properties table.
    If possible, call IDBConnection.cleanDB().
    Warning: cleanDB will remove all Jena models from the databases.
     at com.hp.hpl.jena.db.impl.DriverRDB.throwBadFormat(DriverRDB.java:406)
     at com.hp.hpl.jena.db.impl.DriverRDB.getSystemSpecializedGraph(DriverRDB.java:339)
     at com.hp.hpl.jena.db.DBConnection.containsModel(DBConnection.java:196)
     at com.hp.hpl.jena.db.impl.GraphRDBMaker.hasGraph(GraphRDBMaker.java:132)
     at com.hp.hpl.jena.db.impl.GraphRDBMaker.createGraph(GraphRDBMaker.java:94)
     at com.hp.hpl.jena.rdf.model.impl.ModelMakerImpl.createModel(ModelMakerImpl.java:46)
     at com.hp.hpl.jena.rdf.model.impl.ModelMakerImpl.createModel(ModelMakerImpl.java:49)
     at com.inspur.owl.Persistent.main(Persistent.java:32)[/color]


    在网上也没找到相应的异常处理办法。

    小弟刚刚接触OWL,还望各位高手指点,感激不尽。


    附代码:
       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/protege_db";
    // 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);
    // 使用数据库连接参数创建一个模型制造器
    [color=#FF0000] Model defModel = maker.createModel("Animal");
         // 创建一个默认模型,命名为Costume,因为我要存入的OWL文件名是Costume
       
       FileInputStream read = null;
       try{
        File file = new File("E:/owl/Animal.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("已将本体文件持久化到数据库中");
      }
    }


       收藏   分享  
    顶(2)
      




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

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给baiz_2010发送一个短消息 把baiz_2010加入好友 查看baiz_2010的个人资料 搜索baiz_2010在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 引用回复这个贴子 回复这个贴子 查看baiz_2010的博客2
    发贴心情 
    总算解决了,额...也不算是解决。糊里糊涂的就能读到mysql里了。现把我今天从遇到问题到所做的操作列一下:
    一、根据网上的代码,修改成我本机对应的信息。
    二、增加上相应的jar包,如:mysql的。
    三、出现刚才那个问题。
    四、重启eclipse和 mysql数据库,  还是这个异常。
    五、更换mysql的驱动包, 还是报这个异常。
    六、把jdbc信息换成oracle的,  成功存放到数据库中。  同时排除了jena包的问题。
    七、然后再把jdbc信息改回成mysql的, 竟然成功了!! 真洗具~~~
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/11/29 18:10:00
     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18406
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客3
    发贴心情 
    以下是引用baiz_2010在2010-11-29 18:10:00的发言:
    总算解决了,额...也不算是解决。糊里糊涂的就能读到mysql里了。现把我今天从遇到问题到所做的操作列一下:
    一、根据网上的代码,修改成我本机对应的信息。
    二、增加上相应的jar包,如:mysql的。
    三、出现刚才那个问题。
    四、重启eclipse和 mysql数据库,  还是这个异常。
    五、更换mysql的驱动包, 还是报这个异常。
    六、把jdbc信息换成oracle的,  成功存放到数据库中。  同时排除了jena包的问题。
    七、然后再把jdbc信息改回成mysql的, 竟然成功了!! 真洗具~~~

    感谢分享成功解决经验!

    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/11/29 23:25:00
     
     Avansky 帅哥哟,离线,有人找我吗?
      
      
      威望:1
      等级:大三(研究MFC有点眉目了!)
      文章:103
      积分:675
      门派:W3CHINA.ORG
      注册:2008/12/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Avansky发送一个短消息 把Avansky加入好友 查看Avansky的个人资料 搜索Avansky在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 引用回复这个贴子 回复这个贴子 查看Avansky的博客4
    发贴心情 
    Jena持久化本体到MySQL数据库
     要实现Jena持久化本体到MySQL数据库,便于以后更好地对本体的操作,首先必须在Myeclipse中配置好MySQL,接着就可以在Myeclipse中实现持久化本体。首先完成数据库的连接,代码如下所示:
    public static IDBConnection connectDB(String DB_URL, String DB_USER,  String DB_PASSWD, String DB_NAME)

           return new DBConnection(DB_URL, DB_USER, DB_PASSWD, DB_NAME);
    }  
    接着就可以实现本体存入数据库的操作,从文件读取本体并将其存入数据库的代码如下所示:
    public static OntModel createDBModelFromFile(IDBConnection con, String name, String filePath)

         ModelMaker maker = ModelFactory.createModelRDBMaker(con); 
         Model base = maker.createModel(name); 
         OntModel model = ModelFactory.createOntologyModel(getModelSpec(maker), base);
         model.read(filePath); 
         return model;
    }
    再者,存入数据库的本体如果不能被方便的利用,那么就失去了把本体持久化到数据库的意义。从数据库中得到已存入本体代码如下所示:
    public static OntModel getModelFromDB(IDBConnection con, String name)
    {    
           ModelMaker maker = ModelFactory.createModelRDBMaker(con);    
           Model base = maker.getModel(name);    
           OntModel model = ModelFactory.createOntologyModel(getModelSpec(maker), base);          
           return model;
    }

    public static OntModelSpec getModelSpec(ModelMaker maker)
    {    
           OntModelSpec spec = new OntModelSpec(OntModelSpec.OWL_MEM);           
           spec.setImportModelMaker(maker);    
           return spec;
    }
    最后需要测试把文件持久化到数据库中和从数据库中读出操作的具体实现。代码如下:
    public static void test() {    
         String DB_URL = "jdbc:mysql://localhost/avan";    
         String DB_USER = "root";    
         String DB_PASSWD = "root";    
         String DB = "MySQL";    
         String DB_DRIVER = "com.mysql.jdbc.Driver"; 
       
         try {           
                  Class.forName("com.mysql.jdbc.Driver");    
          } catch (ClassNotFoundException e) {            
                  e.printStackTrace();    
          }    
         String filePath = "file:C://Animal//Animal.owl";    
         IDBConnection con = Jena2SQL.connectDB(DB_URL,DB_USER, DB_PASSWD, DB);       
         Jena2SQL.createDBModelFromFile(con, "Animal",filePath);      
         OntModel Model = Jena2SQL.getModelFromDB(con, "Animal");       
         Jena2SQL.SimpleReadOntology(Model);
    }

    public static void SimpleReadOntology(OntModel model) {    
         for (Iterator i = model.listClasses(); i.hasNext();)
         {        
                OntClass c = (OntClass) i.next();          
                System.out.println(c.getLocalName());    
          }
    }
    其中SimpleReadOntology()方法实现的效果是读取本体中类的简单操作。

    ----------------------------------------------
    本人的论文是基于语义网的搜索引擎技术。
    望同路人多交流!
    Email:avan1017@163.com

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2010/11/30 9:43:00
     
     Avansky 帅哥哟,离线,有人找我吗?
      
      
      威望:1
      等级:大三(研究MFC有点眉目了!)
      文章:103
      积分:675
      门派:W3CHINA.ORG
      注册:2008/12/3

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Avansky发送一个短消息 把Avansky加入好友 查看Avansky的个人资料 搜索Avansky在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 引用回复这个贴子 回复这个贴子 查看Avansky的博客5
    发贴心情 
        
    抱歉,所有以上的全部去掉

    ----------------------------------------------
    本人的论文是基于语义网的搜索引擎技术。
    望同路人多交流!
    Email:avan1017@163.com

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

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给scu86792090发送一个短消息 把scu86792090加入好友 查看scu86792090的个人资料 搜索scu86792090在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 引用回复这个贴子 回复这个贴子 查看scu86792090的博客6
    发贴心情 [讨论]文章中所附代码放在哪里运行?
    你好,请问你在文中所附的代码应该放在哪里运行?还有就是能不能告知这段代码为什么要这么写,有没有参考资料推荐?非常感谢!!
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2015/5/6 16:19:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/12/22 6:16:35

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

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