热门关键字:  ubuntu  分区  Fedora  linux系统进程  函数

OSWORKFLOW-将Osworkflow+MYSQL持久化之二:JDBCStore

来源: 作者: 时间:2007-08-15 Tag: 点击:

 OSWORKFLOW-将Osworkflow+MYSQL持久化之二:JDBCStore
/*
 *Author: Meanson Wang
 *Date: 2005-01-15
 *Email: meansonw@hotmail.com
*/

Osworkflow支持以下的持久化:MemoryStore (default), SerializableStore, JDBCStore, OfbizStore, and EJBStore.

【环境】
WIN2000
Osworkflow 2.7.0
Tomat 5.0.25
Mysql 4.1.7-nt + mysql-connector-java-3.0.15-ga-bin.jar

以下是使用MYSQL来进行持久化,支持文档是OSWF的手册的1.4 Persistence Options.html。里面建议用的是HypersonicSQL.

【步骤一:】建库

在MYSQL里建立一个DB命名为osworkflow
执行压缩文件src/etc/deployment/jdbc里面的mysql.sql建表。

【步骤二:】在TOMCAT里建立一个Datasource,命名为jdbc/oswf

1)Tomcat的admin中的DataSource中配置一个DataSource jdbc/oswf
2)$CATALINA_HOME/conf/catalina/localhost/$appname.xml中配置一个resource link

【步骤三:】修改osworkflow.xml

<osworkflow>
<!--
    <persistence class="com.opensymphony.workflow.spi.memory.MemoryWorkflowStore"/>
-->
<persistence class="com.opensymphony.workflow.spi.jdbc.MySQLWorkflowStore">

 <property key="datasource" value="jdbc/oswf"/>
 <property key="entry.sequence"
                      value="SELECT max(id)+1 FROM OS_WFENTRY"/>
 <property key="entry.table" value="OS_WFENTRY"/>
 <property key="entry.id" value="ID"/>
 <property key="entry.name" value="NAME"/>
 <property key="entry.state" value="STATE"/>
 <property key="step.sequence"
                       value="SELECT max(ID)+1 FROM OS_STEPIDS"/>
                      
 <property key="step.sequence.increment"
     value="INSERT INTO OS_STEPIDS (ID) values (null)"/>
   <property key="step.sequence.retrieve"
     value="SELECT max(ID) FROM OS_STEPIDS"/>                      
     
 <property key="history.table" value="OS_HISTORYSTEP"/>
 <property key="current.table" value="OS_CURRENTSTEP"/>
 <property key="historyPrev.table" value="OS_HISTORYSTEP_PREV"/>
 <property key="currentPrev.table" value="OS_CURRENTSTEP_PREV"/>
 <property key="step.id" value="ID"/>
 <property key="step.entryId" value="ENTRY_ID"/>
 <property key="step.stepId" value="STEP_ID"/>
 <property key="step.actionId" value="ACTION_ID"/>
 <property key="step.owner" value="OWNER"/>
 <property key="step.caller" value="CALLER"/>
 <property key="step.startDate" value="START_DATE"/>
 <property key="step.finishDate" value="FINISH_DATE"/>
 <property key="step.dueDate" value="DUE_DATE"/>
 <property key="step.status" value="STATUS"/>
 <property key="step.previousId" value="PREVIOUS_ID"/>
</persistence>   

    <factory class="com.opensymphony.workflow.loader.XMLWorkflowFactory">
        <property key="resource" value="workflows.xml" />
    </factory>
</osworkflow>

【步骤四:】添加propertyset.xml文件到WEB-INF\classes下。

<propertysets>
    <propertyset name="jdbc"
      class="com.opensymphony.module.propertyset.database.JDBCPropertySet">
        <arg name="datasource" value="jdbc/oswf"/>
        <arg name="table.name" value="OS_PROPERTYENTRY"/>
        <arg name="col.globalKey" value="GLOBAL_KEY"/>
        <arg name="col.itemKey" value="ITEM_KEY"/>
        <arg name="col.itemType" value="ITEM_TYPE"/>
        <arg name="col.string" value="STRING_VALUE"/>
        <arg name="col.date" value="DATE_VALUE"/>
        <arg name="col.data" value="DATA_VALUE"/>
        <arg name="col.float" value="FLOAT_VALUE"/>
        <arg name="col.number" value="NUMBER_VALUE"/>
    </propertyset>
</propertysets>

【其他补充】

以上步骤手册里面都有提到,但绝对原创。因为osworkflow.xml里面的一些内容是我摸索出来的。为什么有补充?看看就清楚了。
由于EXAMPLE是用内存实现的,所以,实际上以上步骤只是把流程流转的数据保存到了数据库,流程定义的LOAD和用户数据尚未保存到数据库,所以,照原来EXAMPLE的使用,在首页先点击HERE建用户test,用此用户登录后使用流程,此时,MSYQL里面的USER表是空的,就会出现添加关系数据库的数据错误【OSWF的MYSQL建表用的是InnoDB,而不是myisam】。
所以,还要补充以下步骤:

在os_user表里添加一条记录,USERNAME=test,PASSWORDHASH不用理会。

这样设置后,按原来的方法也可以顺利执行EXAMPLE,而且,流程的数据会保留在MYSQL里。

那么XML定义文件和USER的持久化呢?下一步就会做到。请继续关注。


 




相关文章:
Scaling out MySQL - Hardware today and tomorro
MySQL教会我使用GnuPG验证软件包
MySQL中MyISAM引擎与InnoDB引擎性能简单测试
mysqladmin在线帮助文档
install a MySQL source distribution
Mysql备份脚本(未验证)
每小时Dump所有mysql数据库到NAS存储设备上
MySQL数据库5.0的my.cnf配置选项
MYSQL建表实例
一些对Mysql DBA有用的脚本
MySql数据引擎简介与选择方法
通向MySQL神秘王国的图形化之路
mysql 中show 命令用法详细介绍
Linux自动备份MySQL数据库 实用方法
如何导入导出MySQL数据库
MySQL创始人力劝用户暂缓部署MySQL 5.1
mysql权限管理
Mysql自动备份脚本
升级mysql
mysql日志
MySql带参数的存储过程编写(动态执行SQL语句)
ERROR 1045 (28000): Access denied for 报错解决
sql优化
配置源码安装的MySQL同时支持多个字符集
MySQL数据表类型 数据类型
sql文件无法读取
mysql 中如何进行IP地址的存放
正在表达式在mysql中的使用
sql mode
linux安装mysql可执行安装包