sql >> データベース >  >> NoSQL >> MongoDB

Mongoでサブドキュメントを整理する最良の方法は?

    これについてはここで少し説明します。最初に読んでください: https://stackoverflow.com/a/27285313/ 68567

    あなたの場合、オプション3(データの一部をプライマリモデルに保持する)がおそらく最良です。重要なのは、無制限のアレイの成長を回避することです。 。

    これは、Mongodbがドキュメントを割り当てる方法と関係があります。 http://docs.mongodb.org/manual/core/storage/ 「MongoDB内のすべてのドキュメントは、ドキュメント自体と余分なスペース、つまりパディングを含むレコードに保存されます。これにより、更新の結果としてドキュメントを拡張できます。」

    ノードが新しいドキュメントを割り当てると、挿入されたドキュメントのサイズとコレクションにすでに存在するドキュメントのサイズに基づいてスペースが割り当てられます。 (上記のリンクで詳細をお読みください。)他のドキュメントよりも桁違いに大きいドキュメントがある場合、これは断片化につながる可能性があります。

    'comments'サブドキュメント配列にドキュメントが多すぎないようにする方法は、$pushコマンドと$sliceコマンドを使用することです。 http://docs.mongodb.org/manual/reference/operator/update/slice/

    したがって、「最新の5」を保存し、アイテムが最初にロードされたときにそれらを表示します。 (または最も古い、または使用したいその他の並べ替え基準。)次に、ユーザーがさらに読み込む方法を提供します。これにより、すべてを含むコレクションへの個別のラウンドトリップが実行されます。




    1. objectidフィールドのないmongodbコレクションの最終更新/挿入/削除操作時間を見つける方法

    2. スモールファイルの問題

    3. Heroku上のNodeを使用したJSONの読み取り、書き込み、保存

    4. プロキシの背後でmongooseを使用してMongoDBデータベースに接続します