jbpm学习笔记(七)——使用oracle数据库

在之前我们所做的例子中所使用的数据库都是jbpm4自带的数据库,这里我们将会使用oracle数据库来实现对流程信息的存储。

1、jbpm数据库连接原理

jbpm使用Hibernate来连接数据库,其主要数据库连接信息的注册文件名为:jbpm.hibernate.cfg.xml,保存在程序的src目录下。

我们之前所使用的自带数据库连接的hibernate注册文件内容如下:

<?xml version="1.0" encoding="utf-8"?>

<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
  <session-factory>
  
     <property name="hibernate.dialect">org.hibernate.dialect.HSQLDialect</property>
     <property name="hibernate.connection.driver_class">org.hsqldb.jdbcDriver</property>
     <property name="hibernate.connection.url">jdbc:hsqldb:mem:.</property>
     <property name="hibernate.connection.username">sa</property>
     <property name="hibernate.connection.password"></property>
     <property name="hibernate.hbm2ddl.auto">create-drop</property>
     <property name="hibernate.format_sql">true</property>
     
     <mapping resource="jbpm.repository.hbm.xml" />
     <mapping resource="jbpm.execution.hbm.xml" />
     <mapping resource="jbpm.history.hbm.xml" />
     <mapping resource="jbpm.task.hbm.xml" />
     <mapping resource="jbpm.identity.hbm.xml" />
     
  </session-factory>
</hibernate-configuration>

我们可以看到注册文件中所连接到数据库是HSQL,这是一个在内存中的临时数据库。

2、建立oracle数据库用户和基本表格

为了使用oracle数据库来存储流程信息,我们首先要在oracle数据库中创建jbpm所需的基本数据库表,这一工作jbpm4已经为我们做好了,我们只需要执行jbpm4.4目录下的jbpm.oracle.create.sql即可,如图7-1所示。


建议oracle的图形话界面使用plSql Developer,在终端下执行@+"完整路径名即可"。

3、更改jbpm.hibernate.cfg.xml

不多说,这里只需要更改Hibernate的连接相关信息即可,更改后的文件内容如下:

<?xml version="1.0" encoding="utf-8"?>

<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
  <session-factory>
  
     <property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property>
     <property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
     <property name="hibernate.connection.url">jdbc:oracle:thin:@localhost:1521:ORCL</property>
     <property name="hibernate.connection.username">jbpm</property>
     <property name="hibernate.connection.password">jbpm</property>
     <property name="hibernate.hbm2ddl.auto">create-drop</property>
     <property name="hibernate.format_sql">true</property>
  
     <mapping resource="jbpm.repository.hbm.xml" />
     <mapping resource="jbpm.execution.hbm.xml" />
     <mapping resource="jbpm.history.hbm.xml" />
     <mapping resource="jbpm.task.hbm.xml" />
     <mapping resource="jbpm.identity.hbm.xml" />
     
  </session-factory>
</hibernate-configuration>

我这里使用的是oracle10g的数据库,所建的数据库用户是jbpm,密码也是jbpm,不用做过多解释。

4、导入Hibernate连接oracle所需的第三方类库

将如下文件导入到web工程的lib目录下即可:

c3p0-0.9.1.jar

antlr-2.7.6.jar

commons-collections-3.1.jar

dom4j-1.6.1.jar

hibernate3.jar

hibernate-jpa-2.0-api-1.0.0.Final.jar

javassist-3.12.0.GA.jar

jta-1.1.jar

slf4j-api-1.6.1.jar

slf4j-nop-1.6.1.jar

此处说明一下可能会遇到导入包冲突的情况,这就得自己查找相关信息了。

最后运行程序,并查询oracle数据库相关表格如下图7-2所示:


表明我们已尽完全配置好了oracle的数据库连接。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值