はじめに
この記事では、Oracle Live Labsのワークショップ「Simplify Business Process Management Using APEX Workflows」をもとに、Oracle APEXで
APEXアプリケーション「Doctor Appointments Made Easy!」を作成し、ワークフローの機能を使って医師の診察を予約・管理するシステムを実装してみます。
こちらの記事で、Oracle APEXを使用して医師の予約ワークフローを作成するプロセスを作成しました。
Oracle APEXの承認コンポーネントを使用してヒューマンタスクを作成するプロセスについて説明します。ヒューマンタスクは、医師予約ワークフローに必要なステップであり、医師または患者が手動で承認、拒否、または完了する必要があります。具体的なステップとして、医師への予約要求の送信、患者の請求書要求の発行、患者のフィードバック要求の発行などのタスクがあります。
上記の手順は、ヒューマンタスクアクティビティに対応しています。ワークフローで使用する前に、承認コンポーネントを使用してタスク定義を作成します。
本記事で行うこと
ヒューマンタスクを作成して以下を行います。
- 医師に予約リクエストを送信する
- 患者の請求書要求の発行
- 患者へのフィードバック要求の提起
ワークフローを作成
APEXアプリケーション「Doctor Appointments Made Easy!」を設計することで、医師の診察を予約・管理する効率的なシステムを実装します。実現のために、以下のアプローチに従っていきます。
- ビジネスロジックを、管理可能で実行可能なステップに分解
- これらのステップの実行を制御するシーケンスと条件を特定
- このビジネスプロセスに関与する組織内の主要な人物を特定
まず、診療予約のビジネスプロセスをステップに分解し、各ステップに関連する登場人物を特定します。以下に概要を示します:
ワークフローへのヒューマンタスクの追加
- 予定申請のタスク定義の作成
-
ページ・デザイナから、「共有コンポーネント」に移ります。
-
画面右上の「作成」をクリックします。
-
タスク定義の作成の欄で、次のように入力し、「作成」をクリックします。
名前: Appointment Request (予約申請)
件名: Appointment for &PATIENT_NAME. on &APPOINTMENT_DATE.
優先度:3-中
-
「タスク定義」のページで、「タスクの詳細ページの番号」が空になっていることを確認します。「タスクの詳細ページの作成」ボタンをクリックして、このタスクの詳細ページを生成します。
次に使用可能なページ番号を使用するかどうかを確認するポップアップダイアログが表示されるので、[OK] をクリックします。
-
「タスク詳細ページ番号」が、生成された「詳細」ページへのリンクを含む「タスク詳細ページ」のURLに置き換えられます。画面左上の[変更の適用] をクリックします。
「タスク定義」ページで、「Appointment Request」をクリックします。
-
Appointment Requestの[タスク定義] ページの設定で、以下のように入力します。
アクション・ソース: SQL問合わせ
アクションSQL問合せ:以下のSQLをコピーして貼り付けます。select * from doctor where dno = :APEX$TASK_PK
APEX$TASK_PKは、記録システムの主キー値(この場合は医師の従業員番号)を保持する置換文字列です。
-
タスク定義の[参加者] セクションに移動し、[行の追加] をクリックし、次を入力します。
参加者種別: 潜在的所有者
値タイプ: 式
値: :DNAME (DNAMEはDOCTOR表のDNAME列を参照します)。 -
[パラメータ] で、[行の追加] をクリックして以下を追加し、[変更の適用] をクリックしてタスク定義を保存します。
静的ID ラベル APPOINTMENT_DATE Appointment Date PATIENT_DESC Consultation Form PATIENT_NAME Patient name
- 請求書要求のタスク定義の作成
-
「共有コンポーネント」に移動します。「ワークフローと自動化」で、「タスク定義」を選択し、「作成」をクリックします。
-
タスク定義の作成ウィザードで次のように入力し、「作成」をクリックします。
名前: Feedback Request
タイプ: アクションタスク
件名: Invoice for &PATIENT_USERNAME. for consultation on &SCHEDULE.
優先度:3-中
-
「タスク定義の編集」ページで、「タスク詳細ページ番号」が空になっていることを確認します。「タスク詳細ページの作成」をクリックして、このタスクの詳細ページを生成します。使用可能なページ番号を使用するかどうかを尋ねるポップアップダイアログが表示されますので、[OK] をクリックします。
-
「タスク詳細ページ番号」が、生成された「詳細」ページへのリンクを含む「タスク詳細ページ」のURLに置き換えられていることがわかります。[変更の適用] をクリックします。
-
「タスク定義」ページで、「Invoice Request」をクリックして、タスク定義を編集モードで開きます。以下を設定します。
[設定]で、次のように指定します。
アクション・ソース: SQL問合せ
アクションSQL問合せ: 次の SQL文を指定します。select * from appointment where BOOKING_ID = :APEX$TASK_PK
※注: APEX$TASK_PKは、レコード・システムの主キー値(この場合は医師の従業員番号)を保持する置換文字列です。
-
「Invoice Request」のタスク定義から、「参加者」セクションに移動し、次のように行を編集します。
参加者タイプ: 潜在的所有者
値タイプ: 静的
値: &PATIENT_USERNAME. -
「パラメータ」タブに移動します。[行の追加] をクリックして以下を追加し、[変更の適用] をクリックしてタスク定義を保存します。
静的ID ラベル DOCTOR_NAME Doctor Name FEES Fees PATIENT_NAME Patient Name
- Feedback Requestのタスク定義の作成
-
「共有コンポーネント」に移動します。「ワークフローと自動化」で、「タスク定義」を選択します。次に、「作成」をクリックします。
-
タスク定義の作成ウィザードで、次の詳細を入力し、「作成」をクリックします。
名前: Feedback Request
種別: アクション・タスク
件名:Feedback for Consultation on &SCHEDULE.
優先度:3-中 -
「タスク定義の編集」ページで、「タスク詳細ページ番号」が空になっていることを確認します。「タスク詳細ページの作成」をクリックして、このタスクの詳細ページを生成します。次に使用可能なページ番号を使用するかどうかを尋ねるポップアップダイアログが表示されます。[OK] をクリックします。
-
「タスク詳細ページ番号」が、生成された「詳細」ページへのリンクを含む「タスク詳細ページ」のURLに置き換えられていることがわかります。[Apply Changes] をクリックします。
-
「タスク定義」ページで、「フィードバック・リクエスト」をクリックして、タスク定義を編集モードで開きます。以下を設定します。
-
[設定]で、次の操作を行います。
アクション・ソース: SQL問合せ
アクション SQL問合せ: 次のSQL文を指定します。select * from appointment where BOOKING_ID = :APEX$TASK_PK
※注: APEX$TASK_PKは、レコード・システムの主キー値(この場合は医師の従業員番号)を保持する置換文字列です。
-
「Feedback Request 」タスク定義ページで、「参加者」タブに移動し、次のように行を編集します。
参加者タイプ: 潜在的所有者
値タイプ: 静的
値: &PATIENT_USERNAME. -
[Task Parameters] で、[Add Row] をクリックして以下のパラメータを追加し、[Apply Changes] をクリックしてタスク定義を保存します。
BOOKING_ID:Booking Id
まとめ
これで、Oracle APEXを使用して医師予約ワークフローを作成するプロセスができました。
次回は、ヒューマンタスクをワークフローに追加していきます。