Docs Menu
Docs Home
/
Relational Migrator
/

図を理解する

項目一覧

  • リレーショナルビュー
  • MongoDB ビュー
  • 表示モードを選択する
  • 色コード
  • Entity Links
  • 図のアクションを取り消すまたは再実行
  • リレーショナル リンクと MongoDB View リンク

このページでは、Relational Migrator で作成された図を解釈する方法について説明します。 各図は 2 つのビューで構成されており、1 つはリレーショナルデータベース用で、もう 1 つは MongoDB database 用です。 ビューには、データベース内のエンティティ間の関係が表示されます。

リレーショナル ビューでは、各ボックスは関係データベース内のテーブルを表します。 ボックスのタイトルは、テーブル名を示します。

各ボックスには、対応する表の列が一覧表示されます。 各列の ボックスは列名とそのデータ型を示します。

一部の列には、テーブル内でのロールを示すためのアイコンがあります。

  • キー アイコンは、テーブルのプライマリキーを示します。

  • リンク アイコンは外部キーを示します。

MongoDB ビューでは、各ボックスは MongoDB database 内のコレクションを表します。 ボックスのタイトルは、コレクション名を示します。

各ボックスには、対応するコレクション内のフィールドが一覧表示されます。 各フィールドの ボックスは、フィールド名とそのデータ型を示します。

コレクションに埋め込みドキュメントまたは配列が含まれている場合、それらのフィールドは同じコレクションにインラインで表示されます。

一部のフィールドには、テーブル内でのロールを示すアイコンがあります。

  • キー アイコンは、コレクションの _idフィールドを示します。 wrappedキー処理戦略を使用する場合、 _idフィールドにはサブフィールドが含まれます。 この場合、 ボックスには 1 つのフィールドに適用される複数のキー アイコンが含まれています。

  • リンク アイコンは、フィールドが外部キーで使用される関係列にマップされていることを示します。

Relational Migrator には、水平分割、垂直分割、関係ビュー、MongoDB ビューなどのさまざまな図表示モードがあります。

表示モード
説明

水平分割

リレーショナル ビューが上部に、MongoDB ビューが下に表示されます。 新しいプロジェクトを作成する場合、水平分割がデフォルトのビュー モードになります。

垂直分割

左側にリレーショナル ビューを表示し、右側に MongoDB ビューを表示します。

リレーショナルビュー

リレーショナルデータベース図のみを表示。

MongoDB ビュー

MongoDB database の図のみを表示します。

表示モードを切り替えるには、左側のナビゲーションバーにある表示モードのオプションをクリックします。

ビュー モード

図内のエンティティは、リレーショナルデータベースまたは MongoDB database のどちらを表すかに基づいて、色付けされています。

  • 関係テーブルがあるエンティティは関係テーブルです。

  • 緑色の強調表示があるエンティティは MongoDB コレクションです。

ボックス間の行は、データベース エンティティを接続する関係を表します。 2 つのボックスが接続されている場合、対応するエンティティは外部キーにリンクされます。 行には、次の関係の機能が表示される場合があります。

  • 関係リンク全体の小さなバーは、エンティティ間の 1 対 1 の関係を示します。

  • prolong (または「のように」)は、関係内の「多」を示します。

Relational Migrator 図は undo と red 関数をサポートします。 前の図アクションを元に戻すか再適用するには、 undo または red 機能を使用します。 これらのアクションを実行するには、図ツールバーまたはキーボード ショートカットのいずれかを使用できます。

を使用できますおよび図のツールバーのボタン:

ツールバーの元に戻すボタンと再実行ボタン

あるいは、キーボード ショートカットを使用することもできます。

関数
Windows ショートカット
Mac ショートカット

Undo

Control + Z

Command + Z

Redo

Control + Y

Command + Y

リレーショナル ビューまたは MongoDB ビューのいずれかでボックスをクリックすると、Relational Migrator は逆のビューで対応するエンティティを強調表示します。 これにより、関係テーブルと MongoDB コレクションが互いにどのようにマッピングされるかを確認できます。

次の例は、店舗の注文を追跡するデータベースのサンプル図です。

このリレーショナルビューは、関係データベース内の複数のテーブルの関係を示しています。

関係図の例

ビューには、次の関係が表示されます。

  • Orderテーブルでは、 OrderIDはプライマリキーです。 CustomerIDOrderStatusIDは外部キーです。 CustomerテーブルとOrderStatusテーブルには、それぞれこれらの外部キーの参照が含まれています。

    • Order CustomerOrderからOrderStatusへの関係はどちらも多対 1 の関係です。

      • カスタマーは複数の注文を持つことができますが、各注文は 1 人のカスタマーにのみ適用されます。 この例では、注文は親であり、顧客は子です。

      • 注文ステータスは複数の注文に適用できます。各注文の注文ステータスは 1 つだけです。 この例では、 Order が親で、 OrderStatus が子です。

  • OrderLineテーブルでは、 OrderLineIDはプライマリキーです。 OrderIDProductIDは外部キーです。 OrderテーブルとProductテーブルには、それぞれこれらの外部キーの参照が含まれています。

    • OrderLine OrderOrderLineからProductへの関係はどちらも多対 1 の関係です。

      • 注文行は、注文内の個々のトランザクションです。 注文には複数の注文行を含めることができ、各注文行は 1 つの注文に適用されます。 この例では、 OrderLine が親で、 Order が子です。

      • 製品は複数の注文行に適用でき、各注文行には 1 つの製品が含まれます。 この例では、 OrderLine が親であり、 Product が子です。

この MongoDB ビューは、前のリレーショナル ビューに対応します。

MongoDB の図の例

ビューに表示されるコレクションとデータ型は、プロジェクトに指定されたマッピング ルールを反映しています。

リンク アイコンは、外部キーで使用される関係列にマップされるフィールドを示します。 たとえば、Order コレクションでは、OrderStatusID フィールドはOrder テーブルとOrderStatus テーブルをリンクする外部キーを表します。

MongoDB の埋め込みデータモデルをより有効に利用するために、次の新しいマッピングルールが作成されています。

  • Orderコレクションには、 OrderLines埋め込み配列としてマッピングするルールが含まれています。 リレーショナルスキーマのOrderLineテーブルは、リレーショナルスキーマの外部キー関係を使用して、 Orderドキュメント内のオブジェクトの配列としてマッピングされます。

    順序マッピングルールの例
  • Customerコレクションには、 Orders埋め込み配列としてマッピングするルールが含まれています。 リレーショナル スキーマのOrderテーブルは、リレーショナル スキーマの外部キー関係を使用して、 Customerドキュメント内のオブジェクトの配列としてマッピングされます。

    カスタマーマッピングルールの例

上記のマッピング ルールはどちらも、マッピングから ID フィールドを削除します。 OrderLinesフィールドとOrdersフィールドは外部キーで参照されるのではなく、親フィールドに埋め込まれているため、フィールドをリンクするために ID フィールドは必要ありません。

戻る