スキーマを分析した後、エクスポートすることができます。これは、スキーマを共有したり、コレクション間でスキーマを比較したりする場合に役立ちます。
始める前に
まだ行っていない場合は、スキーマを分析します。
スキーマを分析します。
[Analyze Schema] をクリックします。
Compass がスキーマを分析すると、コレクションからドキュメントのランダムなサブセットをサンプリングします。サンプリングについて詳しくは、「サンプリング」を参照してください。
スキーマが分析されたら、次の手順でスキーマをエクスポートします。
手順
標準形式スキーマ オブジェクトのプロパティ
標準形式のスキーマオブジェクトには、次のフィールドが含まれています。
プロパティ | データ型 | 説明 |
---|---|---|
| 文字列または配列 | このデータ型のJSONタイプ。詳細については、タイプの公式JSONドキュメントを参照してください。 |
| 文字列の配列 | スキーマに表示する必要があるフィールド。詳細については、公式 JSON ドキュメントの「required」セクションを参照してください。 |
| オブジェクト | 各フィールドのプロパティ 。キーはプロパティ名で、値はサブスキーマです。詳細については、 プロパティの公式JSONドキュメントを参照してください 。 |
| ドキュメント | 配列フィールド内の要素に関するメタデータ。メタデータは埋め込みサブスキーマとして表示されます。詳細については、公式 JSON ドキュメントの「items」セクションを参照してください。 |
これは、使用可能なすべてのフィールドを網羅するものではありません。追加フィールドの詳細については、公式のJSON schema 仕様 を参照してください。
MongoDB 形式スキーマ オブジェクトのプロパティ
MongoDB形式のスキーマオブジェクトには次のフィールドが含まれています。
プロパティ | データ型 | 説明 |
---|---|---|
| 文字列または複数の文字列の配列 | このフィールドの BSON 型。 |
| 文字列の配列 | スキーマに表示する必要があるフィールド。 |
| ドキュメント | 各フィールドのプロパティ 。キーはプロパティ名で、値はサブスキーマです。 |
| ドキュメント | 配列フィールド内の要素に関するメタデータ。メタデータは埋め込みサブスキーマとして表示されます。 |
これは、使用可能なすべてのフィールドを網羅するものではありません。追加フィールドの詳細については、公式のJSON schema 仕様 を参照してください。
拡張形式スキーマ オブジェクトのプロパティ
拡張形式スキーマ オブジェクトには、標準スキーマ フィールドに加えて、これらのフィールドが含まれています。
プロパティ | データ型 | 説明 |
---|---|---|
| 文字列または配列 | このフィールドの BSON 型。 |
| ドキュメント | フィールドに関するメタデータを含むドキュメント。 |
| ブール値 |
|
| float | フィールドがランダムなドキュメントに存在する確率。 |
| integer | このフィールドを持つサンプルからのドキュメントの数。 |
| 配列 | 拡張JSONとしてのサンプル値。サンプル値は最初の 100 文字に制限されています。 |
これは、使用可能なすべてのフィールドを網羅するものではありません。追加フィールドの詳細については、公式のJSON schema 仕様 を参照してください。
制限
Compass は、1000 を超える異なるフィールドを持つスキーマをエクスポートできません。1000 個を超えるフィールドを含むスキーマをエクスポートしようとすると、Compass はエラーを返します。
サンプル スキーマ
次の例では、それぞれが title
フィールドとその映画に関する固有の情報を持つ 3 ドキュメントのコレクションを使用します。
1 [ 2 { 3 "_id": { "$oid": "573a1390f29313caabcd6223" }, 4 "title": "The Poor Little Rich Girl", 5 "plot": "Gwen's family is rich, but her parents ignore her and most of the serv...", 6 "year": 1917, 7 }, 8 { 9 "_id": { "$oid": "573a1391f29313caabcd7616" }, 10 "title": "Salomè", 11 "plot": "Salome, the daughter of Herodias, seduces her step-father/uncle Herod, ...", 12 "year": 1922, 13 "genres": [ "drama", "horror" ] 14 }, 15 { 16 "_id": { "$oid": "573a1392f29313caabcd9c1b" }, 17 "title": "Payment Deferred", 18 "year": 1932, 19 }, 20 ]
上記の例を MongoDB Compass にインポートして、スキーマ出力を試すことができます。サンプル コレクションを MongoDB Compass にインポートするには、次の手順を行います。
JSONドキュメントをクリップボードにコピーします。
上の JSON ドキュメントをコピーします。
上記の例では、次のスキーマが出力されます。