Docs Menu
Docs Home
/
MongoDBマニュアル

時系列

項目一覧

  • 時系列コレクション
  • メリット
  • 使用例
  • 動作
  • metaFields
  • Indexes
  • はじめる

時系列データとは、時間の経過に伴う変化を分析することでインサイトを得られるデータ ポイント列です。

通常、時系列データを構成するのは以下のコンポーネントです。

  • 時間: データ ポイントが記録されています。

  • メタデータ(ソースとも)は、データ シリーズを識別するラベルまたはタグで、ほとんど変更されることはありません。 メタデータは metaField に保存されます。 時系列ドキュメント作成後、metaField を追加することはできなません。 metaField の動作と選択の詳細については、 metaField を参照してください。

  • 測定値(メトリクスまたは値とも): 時間の経過とともに追跡されるデータ ポイントです。一般的に、時間とともに変化するキーと値のペアです。

次の表に、時系列データの例を示します。

測定値
Metadata
株価データ
株価
株式ティッカー、取引所
気象データ
温度
センサー識別子、ロケーション
ウェブサイトの訪問者
閲覧数
URL

時系列データ ストレージの効率化に向け、MongoDB では時系列コレクションを提供しています。

バージョン 5.0 で追加

時系列コレクションは時系列データを効率的にストアします。時系列コレクションでは、同じソースから収集されたデータが、ほぼ同じ時点のデータ ポイントと一緒にストアされるよう、書込みが整理されます。

重要

下位互換性のない機能

以下のダウングレードを行う前に、時系列コレクションを削除する必要があります。

  • MongoDB 6.0 以降から MongoDB 5.0.7 またはそれ以前のバージョンへ

  • MongoDB 5.3 から MongoDB 5.0.5 以前のバージョンへ

時系列データを時系列コレクションにストアすると、通常のコレクションと比較して、クエリの効率が向上し、時系列データやセカンダリインデックスのディスク使用量が削減されます。MongoDB 6.3 以降では、新しい時系列コレクションの時間フィールドとメタデータ フィールド上に複合インデックスが自動的に作成されます。

時系列コレクションは、基礎となる列指向ストレージ形式を使用して、データを時間順にストアします。この形式には、次のメリットがあります。

  • 時系列データの操作の簡素化

  • クエリ効率の向上

  • ディスク使用量の削減

  • 読み取り操作の I/O を削減

  • WiredTiger キャッシュの使用量増加

時系列コレクションは、時間の経過に伴うデータの分析に最適です。次の表は、時系列データの使用例を示しています。

業種
モノのインターネット(IoT)
  • センサーデータ(例: スマートハウスデバイスまたは海上運送)

  • 機械学習と人工知能のスクレイピング

金融サービス
  • 高頻度取引

  • 金融数量分析

  • 銀行業務データ(たとえば、時間の経過に伴う銀行取引の会計)

  • 株式市場データ

小売およびEコマース
  • 取引、販売、価格分析

  • 在庫管理

DevOps
  • アプリケーションのログ記録

  • インフラストラクチャとネットワークの監視

時系列コレクションは、以下のタイプのデータを対象としていません。

  • 順序付けられていないデータ

  • 時間に依存しないデータ

時系列コレクションは通常、他の MongoDB コレクションと同様に動作します。 通常どおり、データの挿入とクエリを行います。

警告

アップデートコマンド内の match 式は、metaField のみを指定できます。時系列ドキュメント内の他のフィールドを更新することはできません。詳細については、「時系列更新の制限」を参照してください。

MongoDB では、時系列コレクションは、内部コレクションを基盤とした書込み可能な非マテリアライズド ビューとして扱われます。データを挿入すると、時系列データは内部コレクションにより最適化されたストレージ形式に自動的に整理されます。

MongoDB 6.3 以降は新しい時系列コレクションを作成すると、MongoDB は metaField フィールドと timeField フィールド複合インデックスも生成します。クエリのパフォーマンスを向上させるため、時系列コレクションのクエリでは新しい複合インデックスが使用されます。複合インデックスもまた、最適化されたストレージ形式を使用しています。

警告

system.profileという名前の時系列コレクションまたはビューを作成しないでください。MongoDB 6.3 以降のバージョンでこれを実行しようとすると、IllegalOperation エラーが返されます。また、以前のバージョンの MongoDB はクラッシュします。

MongoDB 8.0 以降、時系列コレクションでシャードキーとして timeField を使用することは非推奨になります。

また、MongoDB 8.0 以降では、timeField を含むシャードキーで時系列コレクションを作成すると、ログメッセージがプライマリシャードのログファイルに追加されます。さらに、コンフィギュレーションサーバーのレプリカセットのプライマリノードに 12 時間ごとにログメッセージが追加されます。ログメッセージには、timeField を時系列コレクションのシャードキーとして使用することは非推奨とされたため、metaField を使用してコレクションを再シャーディングする必要があることが記載されています。

時系列ドキュメントには、各ドキュメントのメタデータを持つ metaField を含めることができます。MongoDB は、内部ストレージの最適化とクエリ効率の両方で metaField を使用してドキュメントセットをグループ化します。metaField の詳細については、「metaFieldに関する考慮事項」を参照してください。

MongoDB は、時系列コレクションの metaField と timeField の両方に複合インデックスを自動的に作成します。

時系列コレクションを初めて使用する場合は、「時系列コレクションの作成とクエリ」を参照してください。

戻る

参照