モデル駆動型アプリのビジネスプロセスフロー(以下BPF)は、フォームへのデータ入力をステップ化することができ、注文プロセスや申請プロセスなどプロセス化された文脈の中でデータを入れてほしいという場合に利用されます。
ステップ(以下ステージ)はフォーム上で矢羽根のように表現され、あるステージをクリックすると、そのステージを達成するのに必要なデータ入力項目が表示されます(↓イメージ)。
さらに注目すべきは、このBPFでは全体のプロセスにかかっている時間と、現在のステージにかかっている時間を自動的に記録してくれており、プロセスの効率性を見直すための分析材料として活用することができます。
しかし、通常の状態だとすでに完了した各ステージにかかった時間の履歴までは記録されておらず、分析材料としてはあと一歩という感想は否めないと思っています。
そこで今回はその履歴を記録する方法をご紹介します。
①BPFを用意する
まずは BPF を用意しましょう。ここでは具体的な作成方法の説明は割愛しますが、今回の例では以下のような簡単な注文管理用の BPF を作成しました。
BPFを作成すると、同じ名前でDataverseテーブルも自動的に作成されますが、このテーブルに各BPFトランザクションの情報が保管されていることがわかります。
・アクティブステージ=各BPFトランザクションの現在のステージ
※次のステージに進むとアクティブステージも更新される。
・期間=各BPFトランザクションが完了したときに計算される全体のプロセスにかかった所要時間
②履歴を格納するテーブルを作成する
上記のDataverseテーブルのアクティブステージが変更されるタイミングで別テーブルにログを残すようにするような、履歴保管テーブルを作成します。
テーブルとしては以下のような列があれば良いかと思います。
・項番(オートナンバー)
・ステージ(一行テキスト)
・From(日付と時刻)
・To(日付と時刻)
・経過時間(計算式:DateDiff(From,To,TimeUnit.Minutes))
・BPFの対象になっているテーブル(検索)※今回の例で言うと、「注文テーブル」
・BPFテーブル(検索)※今回の例で言うと、「注文BPF」
③ ②で作成したテーブルに履歴を残す Power Automate フローを作成する
上から順に説明していきます。
① 注文BPFテーブルが作成または更新された場合をトリガーにする
② トリガーの情報だけでは取れない情報があるので改めて行を取得する
③ 条件分岐(completedonが空か否か。ステージの最後で「終了」したときはcompletedonに記録されます(この場合、falseになります))
coalesce(outputs('ID_で行を取得する')?['body/completedon'],1)
↓↓以下、真のとき↓↓
④ データ操作-作成 でステージ名を特定する
outputs('ID_で行を取得する')?['body/_activestageid_value@OData.Community.Display.V1.FormattedValue']
⑤ スイッチ で④で作成したデータ本文を入力する
⑥ スイッチ1(最初のステージに関して)
履歴を格納するテーブルに対して、以下のように設定。
検索列は、論理名に複数形のsをつけるので注意。table → tables
⑦ スイッチ2以降(2番目以降のステージに関して)
一つ前のステージのレコードを更新する必要があるので(具体的にはTo列)、まずは一覧でレコードを取得する。フィルターをこのような形で書くことで一意にすることが可能。
列の論理名 eq '前ステージ名' and BPFの対象になっているテーブル(_はじまり,_valueおわり) eq ②で取得した列データ
utcNow()
↑↑以上、真のとき↑↑
↓↓以下、偽のとき↓↓
⑦と同じ要領で一つ前のステージのレコードを更新する。
↑↑以上、偽のとき↑↑
テストしてみる
実際にBPFを進めてみてログが残るかを確認してみましょう。
以下のようにグリッド内に関連テーブルとして表示させることもできますし、ダッシュボードにして各BPFの平均経過時間を取るなんてことも考えられるかと思います。
以上ご参考になれば幸いです。