簡單工作流設計

參考資料

1笆檀,工作流定義

2橄维,有限狀態(tài)機

思路

工作流實際上可以用數據結構中的圖表示尺铣,圖的邊代表從一個節(jié)點跳到另一個節(jié)點的動作,圖的結點代表一個流程的其中一個狀態(tài)争舞,整個圖的定義代表著一個工作流凛忿,因此,設計數據庫的時候兑障,只要能夠將圖表達出來侄非,簡單的工作流設計就很簡單了。

簡單實現

將會定義三張表流译,tb_node, tb_route, tb_history逞怨,其中tb_node是用來定義結點,tb_route用來定義邊福澡,tb_history用來記錄發(fā)生過的動作叠赦。

tb_node的表結構

node_id、node_name

tb_route的表結構

route_id革砸、route_name除秀、current_node_id、next_node_id

tb_history的表結構

history_id算利、route_id册踩、user_id、create_time效拭、update_time

其中tb_node用來定義結點暂吉,tb_route的current_node_id以及next_node_id代表有向圖邊的開始結點和結束結點

一張有向圖通過tb_node、以及tb_route定義完整缎患,例如我需要實現一個報修流程:未處理--》跟進中--》已完成--》已評價慕的,則可以定義ID分別為1到4的tb_node記錄,來表達未處理到已完成4個狀態(tài)挤渔。未處理到跟進中的操作則可以通過tb_route的一條記錄表達肮街,此時current_node_id是1,next_node_id是2判导,說明是從未處理結點到跟進中結點的一個操作嫉父。

tb_history用來記錄業(yè)務發(fā)生的時間、操作人骡楼、以及對應的動作熔号,可以實現對相關業(yè)務發(fā)生時間、操作進行跟蹤記錄鸟整。


應用

簡單工作流常常會應用到ERP系統中引镊,ERP系統中,涉及到很多流程,其中有部分流程不是固定不變的弟头,而是經常因為業(yè)務的變化而需要動態(tài)改變吩抓。假如有個業(yè)務流程原來本身是普通員工填表--》組長審核--》經理審核--》總經理審核,但是后面由于需要加快流程處理變成了普通員工填表--》經理審核赴恨,其他不必要的環(huán)節(jié)都去掉了疹娶,在這種情況下,如果系統在表達業(yè)務流程的代碼中是暴力寫死的伦连,很明顯雨饺,業(yè)務流程變了,你就需要修改你的代碼才能適應這種改變惑淳。但是如果通過工作流來實現原來的業(yè)務流程额港,那樣UI上顯示的業(yè)務流程實際上是遍歷出來的一個圖,而這個圖是可以通過修改邊以及節(jié)點來改變UI上的業(yè)務流程顯示歧焦,這樣就可以實現可配置的業(yè)務流程滿足不同情況下的應用移斩,減少了工作量,系統的應用面就更廣了绢馍。

擴展

1向瓷,其實工作流遠沒有以上講的僅僅幾張表那么簡單,一個完整的工作流還會涉及到自定義表單(實現每個節(jié)點前端應該提交的參數也可以自定義)的設計舰涌,權限的設計等等猖任,本文只是簡單的描述了一下工作流的作用,具體更加復雜的實現瓷耙,可以自行百度哈超升。

2, tb_node,tb_route還可以作為基類哺徊,增加實例表tb_node_instance,tb_route_instance,節(jié)點實例表用來保存節(jié)點執(zhí)行過程中的狀態(tài)乾闰,路由實例表用來保存節(jié)點流轉過程的狀態(tài)落追,這樣的話可以將工作流定義和工作流實際工作過程分開,就如java的類和java的對象一樣涯肩,最后還能增加一個tb_task表與tb_task_instance轿钠,用來表示該工作流代表的一個任務,從而每個工作流實例都是有和具體任務關聯的病苗,該任務可以再設置各種字段保存一段腳本疗垛,從而讓工作流能夠做更多的東西

3,復雜工作流的一些特性:工作流特性

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末硫朦,一起剝皮案震驚了整個濱河市贷腕,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖泽裳,帶你破解...
    沈念sama閱讀 212,383評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瞒斩,死亡現場離奇詭異,居然都是意外死亡涮总,警方通過查閱死者的電腦和手機胸囱,發(fā)現死者居然都...
    沈念sama閱讀 90,522評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瀑梗,“玉大人烹笔,你說我怎么就攤上這事∨桌觯” “怎么了谤职?”我有些...
    開封第一講書人閱讀 157,852評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長铺纽。 經常有香客問我柬帕,道長,這世上最難降的妖魔是什么狡门? 我笑而不...
    開封第一講書人閱讀 56,621評論 1 284
  • 正文 為了忘掉前任陷寝,我火速辦了婚禮,結果婚禮上其馏,老公的妹妹穿的比我還像新娘凤跑。我一直安慰自己,他們只是感情好叛复,可當我...
    茶點故事閱讀 65,741評論 6 386
  • 文/花漫 我一把揭開白布仔引。 她就那樣靜靜地躺著,像睡著了一般褐奥。 火紅的嫁衣襯著肌膚如雪咖耘。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,929評論 1 290
  • 那天撬码,我揣著相機與錄音儿倒,去河邊找鬼。 笑死呜笑,一個胖子當著我的面吹牛夫否,可吹牛的內容都是我干的。 我是一名探鬼主播叫胁,決...
    沈念sama閱讀 39,076評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼凰慈,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了驼鹅?” 一聲冷哼從身側響起微谓,我...
    開封第一講書人閱讀 37,803評論 0 268
  • 序言:老撾萬榮一對情侶失蹤森篷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后堰酿,有當地人在樹林里發(fā)現了一具尸體疾宏,經...
    沈念sama閱讀 44,265評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,582評論 2 327
  • 正文 我和宋清朗相戀三年触创,在試婚紗的時候發(fā)現自己被綠了坎藐。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,716評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡哼绑,死狀恐怖岩馍,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情抖韩,我是刑警寧澤蛀恩,帶...
    沈念sama閱讀 34,395評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站茂浮,受9級特大地震影響双谆,放射性物質發(fā)生泄漏。R本人自食惡果不足惜席揽,卻給世界環(huán)境...
    茶點故事閱讀 40,039評論 3 316
  • 文/蒙蒙 一顽馋、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧幌羞,春花似錦寸谜、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至聂宾,卻和暖如春果善,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背系谐。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評論 1 266
  • 我被黑心中介騙來泰國打工岭埠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蔚鸥。 一個月前我還...
    沈念sama閱讀 46,488評論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像许赃,于是被迫代替她去往敵國和親止喷。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,612評論 2 350

推薦閱讀更多精彩內容