要使用OSWorkflow提供的Query API,先繼承AbstractWorkflow,透過AbstractWorkflow裡的getPersistence method 可連接資料做查詢,其餘的語法參考
程式即可知道,這裡針對幾點做說明:
- WorkflowExpressionQuery參數
這個類別建立時所需的四個參數,第二個對應到資料庫的Table如下所示,第一個則對應到Table中的欄位,欄位如何對應由名稱應可明瞭,不另作說明。
常數 | Table |
FieldExpression.ENTRY | OS_WFENTRY |
FieldExpression.CURRENT_STEPS | OS_CURRENTSTEP |
FieldExpression.HISTORY_STEPS | OS_HISTORYSTEP |
第三個參數為運算元,只有四種如下:
運算元 | 說明 |
FieldExpression.EQUALS | 等於 |
FieldExpression.NOT_EQUALS | 不等於 |
FieldExpression.GT | 大於 |
FieldExpression.LT | 小於 |
- 巢狀運算
如果要比較的不只一個欄位,就需要用到巢狀運算,使用class NestedExpression,底下是一個官方文件的範例: // Get all finished workflow entries
//where the current owner is 'testuser'
Expression queryLeft = new FieldExpression(
FieldExpression.OWNER,
FieldExpression.CURRENT_STEPS,
FieldExpression.EQUALS, 'testuser');
Expression queryRight = new FieldExpression(
FieldExpression.STATUS,
FieldExpression.CURRENT_STEPS,
FieldExpression.EQUALS,
"Finished",
true);
WorkflowExpressionQuery query =
new WorkflowExpressionQuery(
new NestedExpression(
new Expression[] {queryLeft, queryRight},
NestedExpression.AND));