引自http://www.cnblogs.com/armymen1980/archive/2008/10/22/1316699.html
实现了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());
}
}
此主题相关图片如下:
分享到:
相关推荐
很经典!我在学习!和大家一起分享!Jena持久化OWL到Mysql
利用jena API查询OWL本体 最近在学习本体和语义网。学习了OWL,也尝试着用了一下jena API对OWL本体进行查询。
使用Jena将本体存入MySQL——文档和例子
这是一个jena api解析owl文件的简单案例。
是一个jena 解析.owl 文件的例子!
JENA教程(包括生成RDF和写本体到MySQL中,很适合入门,很详细)JENA教程(包括生成RDF和写本体到MySQL中,很适合入门,很详细)JENA教程(包括生成RDF和写本体到MySQL中,很适合入门,很详细)JENA教程(包括生成RDF和写本体...
本体,应用程序则是使用Jena来做同样的工作,当然这些应用程序还是得由我 们来编写。其实Protege本身也是在Jena的基础上开发的,你看如果Protege 的console里报异常的话,多半会和Jena有关。最近出了一个Protege OWL...
一个用jena处理protege生成的owl文件的小例子,可以输出本体类,属性等等,可以借鉴学习一下
将OWL本体持久化到MySQL,最稳当的包,高于2.6版本的包找不到持久化方法了
这是用jena对本体进行解析的很好的一篇文档,大家好好参考哦
以下的文章主要介绍的是使用Jena,将本体文件存入MySQL数据库的实际操作步骤
这个资源是用java编写的解析出本体,输出结果为你所建立本体里各个类的关系。
基于Jena的本体推理,使用sparql语言对本体进行查询。
学习过程中做的一个利用Jena实现的推理...内容包含:构建model,实现数据库与model关联,读入本体文件,构建规则,使用规则构建推理机,构建查询,实施查询,输出查询结果,将本体持久化到Mysql数据库。希望有帮助。
jena的中文教程,适合不想去官网看原版教程的人。适合新手入门学习jena的基本操作。jena可以解析本体,可以将建模工具和java联系起来
Jena API 的使用说明,包括简单的使用示例,是《An Introduction to RDF and the Jena RDF API》的译文
Jena,owl,开发材料文档,内含许多实例。
很详细的Jena+中文教程本体API的介绍
Jena实现本体的推理,包括.rules规则等,使用sparql语言对本体进行查询
owl2rl-jena 一个示例项目,在Apache Jena中使用OWL2 RL规则集进行基于本体的推理。 有关更多信息,请参见。