明確で効果的な視覚モデルを作成することは、堅牢なシステム設計の基盤です。ステークホルダーと開発者が図を確認する際には、システムの機能を曖昧さなく理解できる必要があります。Use Case Diagramは、アクターとシステムの間の相互作用を捉えることで、この目的を果たします。しかし、論理がしっかりしていなければ、これらの図を作成する際に混乱が生じることがあります。このガイドは、図が正確で読みやすく、価値のあるものになるよう、構造的なアプローチを提供します。

🛠️ フェーズ1:システム境界の定義
1つのボックスや棒人間を描く前に、範囲を明確にしなければなりません。システム境界は、システムの内部と外部を定義します。この区別は非常に重要であり、どの要素が機能要件の一部であり、どの要素が外部の影響であるかを決定するからです。
- コアシステムの特定:システムを表す長方形を明確にラベル付けしてください。”The System”のような曖昧なラベルは避け、”決済処理モジュール”や”在庫管理システム”といった具体的な名前を使用してください。
- 外部エンティティのマーク:長方形の外にあるものはすべてアクターまたは外部システムです。サブシステムでない限り、これらを境界内に描かないようにしてください。
- データフローの明確化:Use Case Diagramはデータフローを明示的に示しませんが、境界がデータが機能論理に入り出しする場所を示唆しています。
明確な境界がないと、アクターが提供されるサービスではなく内部の詳細とやり取りしているように見えることがあります。これにより、モデルがやりすぎで維持が難しくなってしまいます。
👥 フェーズ2:アクターの正しく特定
アクターは、Use Caseシステムとやり取りする人間やシステムが果たす役割を表します。彼らは行動の発起者または出力の受領者です。アクターを正しく特定することは、図作成において最も一般的な誤りの原因です。
アクターとは何か?
アクターは、特定の人物ではなく、役割を指します。1人の人物が複数の役割を果たすこともあり、1つの役割を複数の人物が果たすこともできます。たとえば、「マネージャー」がアクターであり、「ジョン・スミス」ではありません。また、アクターは外部APIやレガシーデータベースなどの他のシステムであることもあります。
- 主なアクター:これらは特定の目標を達成するために相互作用を開始するものです。システムのユーザーです。
- 補助的アクター:これらは、タスクを完了するためにメインシステムがやり取りするシステムやサービスです。データやサービスを提供しますが、Use Caseを開始するものではありません。
- 一般的 vs. 特定:特定の個人をリストに含めないでください。代わりに「顧客」「管理者」「第三者サービス」などの役割ベースの名前を使用してください。
よくあるアクターの誤り
| 誤ったアプローチ | 正しいアプローチ |
|---|---|
| “ジョン・ドー”とラベル付けする | “登録ユーザー”とラベル付けする |
| アクターをシステム境界内に配置する | アクターをシステム境界外に配置する |
| 各画面ごとにアクターを作成する | 機能的役割ごとにアクターを作成する |
| システム間のアクターを無視すること | 外部APIをアクターとして含めること |
役割ベースの命名規則と正しい配置を守ることで、人員の変更があっても図は安定したまま保たれる。
🎯 フェーズ3:ユースケースの定義
ユースケースは、アクターに価値を提供する完全な機能単位を表す。単一の行動ではなく、目標を達成するための行動の順序である。ユースケースの命名規則は明確さにとって重要である。
命名規則
ユースケース名は、アクターの視点から行動を説明する動詞フレーズでなければならない。簡潔であるべきだが、単独で理解できるほど十分に説明的でなければならない。
- 動詞+目的語形式:例として「注文処理」、「レポート生成」、「プロフィール更新」などがある。行動ではなく特定の文書を指す場合を除き、「注文処理」のような名詞は避けること。
- 目標志向:自分に問うてみよう。「アクターはどのような成果を達成したいのか?」答えが「請求書を支払う」ならば、ユースケースは「請求書の支払い」であり、「請求書支払い画面」ではない。
- 範囲の一貫性:すべてのユースケースが同じ抽象度にあることを確認する。高レベルの目標(「アカウントの管理」)と低レベルの手順(「パスワードを入力する」)を混在させてはならない。
粒度の確認
ユースケースが広すぎると曖昧になり、狭すぎるとごちゃごちゃになる。良い目安は、ユースケースがアクターにとって1回のセッションで実行可能であるか、明確なビジネス取引を表していることである。複雑なワークフローは、関係性で結ばれたより小さなユースケースに分割するべきである。
🔗 フェーズ4:関係のマッピング
ユースケース図の力は、アクターとユースケースの間、およびユースケース同士の関係性にある。これらの線はシステムの論理を伝える。
関連
アクターとユースケースを結ぶ実線は、そのアクターがその機能とやり取りしていることを示す。すべてのアクターには少なくとも1つの関連があり、すべてのユースケースには少なくとも1人のアクターが関連しているべきである。
- 方向性:しばしば双方向に描かれるが、論理的な流れは通常、要求を開始するアクターから始まる。
- 複数のアクター:1つのユースケースは複数のアクターにリンクできる。たとえば、「レポートの閲覧」は「マネージャー」と「監査担当者」にリンクされることがある。
包含関係
包含関係は、あるユースケースが常に別のユースケースの振る舞いを組み込んでいることを示す。含まれるユースケースは、ベースとなるユースケースが目標を達成するために不可欠である。これはサブルーチンと考えるとよい。
- 使用するタイミング:複数のユースケースに共通する機能に使用する。たとえば、「ユーザー認証」は「ログイン」、「パスワードのリセット」、「資格情報の変更」に含まれる可能性がある。
- 表記法:通常、ベースとなるユースケースから含まれるユースケースへ向かう破線の矢印で、「<<include>>」というラベルを付けて表す。
拡張関係
拡張関係はオプションの動作を示します。拡張されるユースケースは、特定の条件下でベースとなるユースケースに機能を追加します。これはエラー処理やオプション機能に有用です。
- 使用するタイミング:例外やバリエーションの場合に使用します。例えば、「通知を送信」は、支払いが失敗した場合にのみ「注文を確定」を拡張する可能性があります。
- 条件付きの動作:常に拡張ポイントまたは条件を明確に定義してください。ベースとなるユースケースは拡張なしでも動作します。
一般化
一般化は継承に使用されます。特殊化されたアクターまたはユースケースは、一般化されたものから動作を継承します。これにより図内の重複を減らすことができます。
- アクターの継承: 「プレミアムユーザー」が「登録ユーザー」から継承する場合、再び「登録ユーザー」のすべての関連を描く必要はありません。
- ユースケースの継承: 「月次レポートの生成」が「レポートの生成」の一種である場合、階層を示すために一般化を使用できます。
🚫 フェーズ5:一般的な落とし穴を避ける
経験豊富なモデラーでさえミスを犯します。以下のチェックリストは一般的な誤りとその解決法を示しており、図の品質を確保するために役立ちます。
| 落とし穴 | 影響 | 解決策 |
|---|---|---|
| 重複するアクター | 誰が何を行うのかが不明瞭になる | アクターを明確に分離する;役割が似ている場合は一般化を使用する |
| 循環的な依存関係 | フローを破壊する論理的なループ | include/extendの論理を確認する;ベースとなるユースケースが自己完結していることを確認する |
| 関係が多すぎる | 図が読みにくくなる | 共通する動作を統合する;詳細な論理は注記を使用する |
| アクターが欠落している | システムの視点が不完全になる | すべての機能要件を確認する;各ユースケースに開始者があることを確認する |
| インターフェースの混乱 | UIと論理を混同する | 図を画面のレイアウトではなく、機能性に集中させてください |
| 使用されていないユースケース | モデル内の無効なコード | 定期的に見直しを行い、アクターもしくは依存関係のないユースケースは削除してください |
🔍 フェーズ6:検証チェックリスト
図を最終確定する前に、この検証リストを確認してください。これにより、モデルが堅牢であり、開発チームの準備ができていることを保証します。
- 完全性:すべてのユースケースに少なくとも1つのアクターが存在していますか?
- 一貫性:すべてのアクター名が用語集と一貫していますか?
- 明確性:システム境界が明確にラベル付けされていますか?
- 正確性:関係性(include/extend)が要件と論理的に一致していますか?
- 可読性:レイアウトは明確ですか?線が不必要に交差していませんか?
- 拡張性:既存の構造を崩すことなく、新しいユースケースを追加できますか?
- 整合性:図は上位のビジネス目標と整合していますか?
- 文書化:複雑なユースケースは、注記や説明で文書化されていますか?
🔄 フェーズ7:時間の経過に伴う変更の管理
要件は進化します。ソフトウェアはほとんど常に静的ではありません。ユースケース図は、システムの現在の状態を反映する動的な文書として扱わなければなりません。この文書を維持することは、作成することと同じくらい重要です。
バージョン管理
変更を追跡してください。ユースケースが追加、変更、または削除された場合は、図のバージョンを更新してください。これにより、監査やシステムの進化の理解が容易になります。
影響分析
要件が変更された場合、それが図にどのように影響するかを分析してください。新しいアクターが導入された場合は、既存のユースケースを変更する必要があるか確認してください。ユースケースが削除された場合は、他のユースケースがinclude関係でそれ依存していないか確認してください。
ステークホルダーのレビュー
ステークホルダーと図を定期的に見直してください。彼らは、モデルがシステムに対する彼らの認識とまだ一致しているかを特定できます。このフィードバックループにより、図が関連性を保ちます。
📏 フェーズ8:明確性と一貫性の確保
視覚的な一貫性は理解を助けます。図がごちゃごちゃしていると、その背後にある論理もごちゃごちゃしているように感じられるかもしれません。
- 整列:アクターとユースケースを整列させる。グリッド線や余白を使って、構造的なレイアウトを構築する。
- 色の使用:純粋なHTMLではCSSスタイルの使用を避ける必要がありますが、実際のモデル作成ツールでは、主なアクターと補助的なアクターを区別したり、非推奨のユースケースを強調するために色を使用することを検討してください。
- ラベル:すべてのラベルが読みやすいことを確認する。業界標準の用語でない限り、省略語は避ける。
- 余白:線がテキストと重複しないように、要素の周囲に十分な余白を確保する。
🧩 他のモデルとの統合
ユースケース図は単独で使用されることがほとんどありません。他のモデル技法と統合することで、最も効果を発揮します。
- シーケンス図:特定のユースケース内の相互作用の流れを詳細に示すために、シーケンス図を使用する。
- クラス図:ユースケースに関与するオブジェクトを定義するために、クラス図を使用する。
- 状態図:ユースケースに関与するオブジェクトのライフサイクルを示すために、状態図を使用する。
これらのモデルをリンクすることで、ユースケース図自体がごちゃごちゃにならずに、システム全体の包括的な視点を構築できます。ユースケース図は機能を理解するための入り口のままであり、他の図は実装の詳細を提供します。
🏁 最終レビュー手順
図を配布する前に、最終的な妥当性チェックを行う。
- すべてのラベルを声に出して読み、文法的に意味が通ることを確認する。
- どのアクターも接続なしに孤立していないことを確認する。
- include/extend関係が互換的に使用されていないことを確認する。
- システム境界がすべての意図された機能を含んでいることを確認する。
- 図が1ページに収まっているか、論理的にページ分割されていることを確認する。
この構造的なチェックリストに従うことで、図が単なる絵ではなく、コミュニケーションのための機能的なツールになることが保証されます。ビジネスニーズと技術的実装の間のギャップを埋めます。役割、目的、関係性に注目することで、時間と変化の試練に耐えるモデルを構築できます。
思い出してください。目的は明確さです。ステークホルダーが図を見てシステムの機能を理解できれば、成功です。価値に注目し、構造を論理的に保ち、要件の変化に応じて図を維持し続けましょう。











