分享
 
 
 

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

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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的持久化呢?下一步就会做到。请继续关注。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有