现在的位置: 首页 > 综合 > 正文

使用OSWorkflow提供的Query API[转史蒂芬笔记]

2013年08月11日 ⁄ 综合 ⁄ 共 980字 ⁄ 字号 评论关闭
要使用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));

 

抱歉!评论已关闭.