新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   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)/描述逻辑/本体 』 → 使用jena持久化OWL本体到MySQL 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 100692 个阅读者浏览上一篇主题  刷新本主题   平板显示贴子 浏览下一篇主题
     * 贴子主题: 使用jena持久化OWL本体到MySQL 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     shalen2008 帅哥哟,离线,有人找我吗?金牛座1986-5-16
      
      
      等级:大一(猛啃高等数学)
      文章:16
      积分:190
      门派:W3CHINA.ORG
      注册:2008/1/26

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给shalen2008发送一个短消息 把shalen2008加入好友 查看shalen2008的个人资料 搜索shalen2008在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 点击这里发送电邮给shalen2008 引用回复这个贴子 回复这个贴子 查看shalen2008的博客楼主
    发贴心情 使用jena持久化OWL本体到MySQL

    遇到了好多问题,终于实现了OWL本体到MySQL的存储和读取,首先应该配置好环境,在项目中添加jena的相关包,值得注意的是MySQL的驱动和版本要一致。
        我是用protege创建OWL本体,然后再从OWL文件中读取,存入MySQL数据库,注意在保存OWL本体的时候最好项目另存为的LANGUAGE选择RDF/XML,最好用UTF-8编码,这样读取出错的机会少一些,图片在附件中。
        下面是操作的java代码:

    /* 连接数据库 */
    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 newmodel = ModelFactory.createOntologyModel(
     getModelSpec(maker), base);
        newmodel.read(filePath);
        return newmodel;
    }

    /* 从数据库中得到已存入本体 */
    public static OntModel getModelFromDB(IDBConnection con, String name) {
        ModelMaker maker = ModelFactory.createModelRDBMaker(con);
        Model base = maker.getModel(name);
        OntModel newmodel = ModelFactory.createOntologyModel(
     getModelSpec(maker), base);
        return newmodel;
    }

    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/expert";
        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://expert//Expert.rdf-xml.owl";
        IDBConnection con = JaneUtils.connectDB(DB_URL,DB_USER, DB_PASSWD, DB);
        System.out.println(con);
      
        JaneUtils.createDBModelFromFile(con, "expert",filePath);  
        OntModel model = JaneUtils.getModelFromDB(con, "expert");
        JaneUtils.SimpleReadOntology(model);
    }

    /* 简单读取本体中的各个class */
    public static void SimpleReadOntology(OntModel model) {
        for (Iterator i = model.listClasses(); i.hasNext();) {
            OntClass c = (OntClass) i.next();
            System.out.println(c.getLocalName());
        }
    }


    此主题相关图片如下:
    按此在新窗口浏览图片


    [此贴子已经被作者于2008-3-31 19:57:53编辑过]

       收藏   分享  
    顶(3)
      




    ----------------------------------------------
    喜欢编程,热爱游戏事业

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2008/3/26 22:58:00
     
     GoogleAdSense金牛座1986-5-16
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Semantic Web(语义Web)/描述逻辑/本体 』的所有贴子 点击这里发送电邮给Google AdSense 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/21 10:51:08

    本主题贴数44,分页: [1] [2] [3] [4]... [5]

     *树形目录 (最近20个回帖) 顶端 
    主题:  使用jena持久化OWL本体到MySQL(2646字) - shalen2008,2008年3月26日
        回复:  您好,我是用jena直接读本体文件的,类和数据是分开存储的,请问怎么能获得一个类的所有实例啊?该类..(121字) - dongying_owl,2012年6月8日
        回复:  从MySQL中读取个体我是在protege中创建个体的,导出来类和个体在一个OWL文件中,一块..(465字) - lijunhuaforever,2012年6月4日
        回复:  import struts.bean.Bean;import struts.bean.Book;..(291字) - nhwshy,2012年4月20日
        回复:  very good!(11字) - renzhigen12,2011年5月6日
        回复:  谢谢楼主 很有参考价值(21字) - sos909111,2010年6月5日
        回复:  (4字) - shenxin1986,2010年6月4日
        回复:  楼主的QQ是多少?我没有运行出来,请教一下。。。。我的QQ942886965..(63字) - angleangleangle,2010年5月5日
        回复:  MySQL的驱动和版本要一致。楼主用的是那个版本的?mysql和驱动..(60字) - shenxin1986,2010年4月21日
        回复:  怎么老是提示错误?(18字) - angleangleangle,2010年4月20日
        回复:  /* 连接数据库 */public static IDBConnection connectDB..(225字) - angleangleangle,2010年4月20日
        回复:  为什么我的运行不出来?(22字) - angleangleangle,2010年4月20日
        回复:  楼主是在什么环境下实现的?(28字) - angleangleangle,2010年4月19日
        回复:  protege怎样连接jdbc的?(25字) - angleangleangle,2010年4月19日
        回复:  protege怎么连接的上数据库的呢?(31字) - angleangleangle,2010年4月19日
        回复:  请问楼主这两个过程:从OWL文件中读取,存入MySQL数据库,是怎么实现的呢。..(70字) - angleangleangle,2010年4月19日
        回复:  谁能不能给个从客户端读入信息,然后存储到本体数据库中的一些操作啊。谢谢了。因为是毕设,所以请大家一..(137字) - lzx211314,2010年4月19日
        回复:  好东西哦,谢谢(14字) - lzx211314,2010年4月16日
        回复:  本体持久化就是把本体存入数据库?那查询的时候就不用SPARQL了,只要用SQL就行了吗?望..(115字) - Avansky,2010年4月15日
        回复:  你好在研究推理那块,不知道jena如何推理呢,例如,写了一个规则[rule1:(?a http:/..(600字) - springbird,2009年12月30日

    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    3,621.094ms