当前位置导航:炫浪网>>网络学院>>编程开发>>JAVA教程>>J2EE

分享:轻松维护RDF元数据模型(图)


  摘要
  
  资源描述框架(Resource Description Framework RDF)是一种以XML格式描述元数据的标准格式。Jena是一种用于将关系数据库或是文本文件中所表示的数据建立为元数据模型的框架方法。Protégé 用用来创建RDF元数据文档的编辑工具。 建立这种数据库和文件的元数据模型需要由用户自己定义脚本。本文介绍介绍了SemantiRDFUtils这种脚本,它拥有多个功能块可以用于维护Jena RDF 元数据模型.(2200词,2005-7-4) By Venkata N.VAsam
  
  与XML成为不同软件厂商之间数据交互的标准过程相似,资源描述框架(RDF)也沿着这条道路前进,希望能够成为描述与交互元数据的标准。XML 使用文件类型定义(DTD)和XML格式定义(XSD)来描述数据。RDF使用XML语法和RDF Schema(RFDS)来将元数据描述成为数据模型。
  
  本文介绍了一种使用Jena RDF API 编写的用户自定义工具,使用这种工具来管理存储在关系数据库或是文本文件的数据模型。这种工具是由HP实验室开发的,Jena框架是一个RDF,RDFS以及OWL(Web Ontology Language)的开源实现, 它包含着一个基于规则的推论引擎。它提供了建立和操纵RDF模型的Java API。本文介绍的SemanticRDFUtils.bat是一种使用Jena开发的脚本。使用这种脚本,我们可以维护存储在关系数据库和文本文件中的元数据模型。本文还介绍了怎样使用Protégé来将建RDF的语意描述文件(.rdfs)和数据文件(.rdf)。
  
  软件安装
  
  在使用SemanticRDFUtils.bat之前必须先安装以下的软件。关于以下工具的链接请参看文中所附的资源。
  J2SE 1.3 或更高的版本
  Jena 2.0
  Oracle 9.2.0.1.0
  Apache Ant 1.5.4 或更新的版本
  Protégé 2.1
  
  RDF和RDFS 文件简要介绍
  
  下面的XML格式的RDF和RDFS文件用于显示一个字母顺序的交叉引用模型。它们是使用Protégé 2.1 的图形界面工具创建的。当执行脚本和RDF查询工具的时候我们可以动态的引入RDF文件。RDFS文件则在我们使用Protégé 给RDF文件中加入更多数据时使用。
  
  
列表1. RDFTest1.rdf

  
 

  
列表 2. RDFTest1.rdfs

  
 

  Jena和Protégé概述
  
  本节在宏观层面上介绍Jena和Protégé。用户可以在附加资源中得到关于这两个产品更多的信息。本文的目的是使您对Jena和Protégé有一个比较清晰的理解。
  
  Jena RDF 和RDQL
  
  RDF数据模型是一个声明(statement)的集合,每一个声明都包括三个部分:资源,属性和值。 资源(resource)可以是任何使用URI标示的内容,它可以包含其它属性。每一个属性有一个值。
  
  Jena可以将RDF模型保存在关系数据库或是文件当中。RDQL是用来查询RDF模型的语言。RDF提供一种节点可以为资源或是文本的有向图(有向图的概念请参看《离散数学》)。RDQL则提供一种方式,由用户定义一种图模式,使用这种模式对目标图集合进行匹配,获得所有符合定义模式的结果。图1 使用RDF图来表示列表1和列表2中文件
  
 

  
图1:范例RDF文件的RDF 图表示

  
  上图中,椭圆代表资源,长方形代表描述。资源通过箭头连接到其它的资源或是描述值(一个对象或是一个值)上,这样一组关系形成一个三元组,成为一个声明(statement)。
  
  下面给我一个RDQL查询的例子。三元组(?x "97")是一个声明。X是一个绑定的变量用来代表一个资源;http://www.vvasam.com/Maana#value是一个叫做“value”的属性;97是这个属性的值。
  
  SELECT ?x WHERE (?x "97")
  
  Jena的toolkit提供了一个在命令行方式执行的Java类(jjena.rdfquery)来进行RDQL查询。下面的例子演示了如果使用这个命令进行查询并将查询结果存入test1.rdql当中。
  java jena.rdfquery --data RDFTest1.rdf --query test1.rdql
  x
  ================================================
  http://www.vvasam.com/Maana#RDFTest_Instance_8
  
  注意:通过文后的资源链接来获得关于RDF和RDQL更多的信息。
  
  RDF 中使用Protégé
  
  Protégé 是一个用来建立和编辑ontologies和知识库的GUI工具。Protégé可以在RDF格式下创建和保存数据。在使用Protégé建立RDF模型时,需要在新建一个工程的时候选取RDF Schema,如图2所示。
  
 

  
图2. RDF Schema工程

  
  在Protégé's工程菜单选择新建工程时,选择格式(Select Format)对话框会弹出。点击OK按钮,图3的窗口会出现。
  
 

  
图3. 缺省Protégé工程视图

  
  正如您在图3中所看到的那样,Protégé有一些标签。本文主要介绍其中的Classes,Instances和Algernon标签。
  
  图4显示了Protégé的保存对话框。在其中用户可以填入工程,类文件,实例文件,和命名空间的名字。如图4所示,类文件名中包括RDF Schema的信息,实例文件名中包括RDF的数据。命名空间中以唯一URI的方式标示出RDF模型。
  
 

  
图4: Protégé's保存对话框

  
  图5和图6显示的是Protégé's类标签和实例标签,分别表示了列表1和列表2中的.rdf和.rdfs文件。这些文件使用Protégé's schema 格式创建。
  
 

  
图5: Protégé的类标签

  
 

  
图6: Protégé的实例标签

  
  Protégé中的Algeronon 查询
  
  Protégé's的Algernon query标签为进行Algernon查讯提供了一个图形界面,用户可以在这个UI当中进行查询,并查看结果。Algernon是一种基于三元组的查询语言,如图7所示Algernon将资源以遍历(traversal)路径的方式返回给用户。缺省的Algernon并不会如下图那样显示。要看到这个标签,用户必须从工程菜单的设置子菜单中选择。
  
 

  
图7. Algernon 标签

  
  Jena和Protégé之间的命名(terminology)映射
  
  由于Jena和Protégé是两个不同的开源技术,所以他们的RDF 命名(terminology)存在差别。下表中列出了这些命名规则,用户可以更具这些命名规则来创建和处理RDF文件。
  
  
表1. Jena 和 Protégé 命名比较

  
 

  Jena 的语义RDF工具
  
  一节讲解了一些用于维护Jena数据库和文件模型的有用的工具/脚本。这些脚本文件包含在SemanticRDFUtils-scripts-files.zip文件当中,您可以在资源当中找到。下面的列表中描述了这些脚本文件可以执行的任务。当用户以没有任务ID号作为参数的命令行方式执行SemanticRDFUtils批处理文件时,下面的内容将会出现在你的控制台当中
  
 

  以上各任务ID的意思分别为:
  
  1:建立并初始化一个Jena系统表,系统模型名为JenaRDFSystem
  2:建立数据库模型
  3:删除一个数据库模型
  4:列出所给出模型当中的内容
  5:将RDF/XML文件导入数据库
  6:列出存在数据库模型的名字
  7:将数据库模型导出到RDF/XML文件中
  8:删除一个数据库模型当中的所有内容
  9: 为不同RDF/XML文件模型建立一个合并的RDF/XML文件
  10:建立不同RDF/XML文件直接的交集文件。
  11: 建立不同RDF/XML文件直接的差集文件。
  12:得到给定模型的大小
  13:将RDF查询结果保存在RDF/XML文件当中
  14:从RDF查询结果模型当中删除资源
  
  SemanticRDFUtils脚本使用SemanticRDFUtils.properties文件储存配置信息。下表给出了配置信息中的所有属性:
  
  
表 2. 属性设置

  

  任务
  
  第一个任务是在数据库中建立一个Jena 系统表并要求下列属性的正确值:
  
  rdf_sytem_model_name
  db_user
  db_password
  isRDFInDB
  url
  
  第二个任务是在数据库建立一个新的RDF模型并要求下列属性的正确值:
  
  rdf_sytem_model_name
  db_user
  db_password
  isRDFInDB
  url
  modelName (如果这个属性为空,那么脚本会提示用户从键盘输入值)
  
  第三个任务是从数据库中删除RDF模型并要求以下属性的正确值:
  
  rdf_sytem_model_name
  db_user
  db_password
  isRDFInDB
  url
  modelName (如果这个属性为空,那么脚本会提示用户从键盘输入值)
相关内容
赞助商链接