Go を使用して MongoDB の複数の会場にわたるユーザー エージェントの発生を効率的にカウントするにはどうすればよいですか?
Oct 26, 2024 am 11:00 AMGo で MongoDB の複数の属性値をチェックして項目リストを取得する
目的は、複数の属性値を照合して MongoDB 内の項目のリストを取得することです。 SQL の IN 条件に似た属性値。この場合の目的は、会場リストの配列を含む JSON ドキュメント内の「linux」および「ubuntu」ユーザー エージェントの出現をカウントすることです。各会場リストには、ユーザー エージェント名と値を含む合計サブドキュメントの配列があります。
解決策には、MongoDB の集計フレームワークと Go の mgo パッケージを使用することが含まれます。集計パイプラインの内訳は次のとおりです:
- 会場 ID によるフィルター: $match パイプラインを使用して、venueList.id フィールドが目的の会場 ID と一致するドキュメントを選択します (例: "VID1212" および "VID4343")。
- Unwind Venue List: $unwind パイプラインを使用して、venueList 配列を非正規化し、会場ごとに個別のドキュメントを作成します。
- Filter Venue ID: アンワインド後、ドキュメントを再度フィルタリングして、目的の会場 ID のみが残るようにします。
- Unwind Sum Subdocument: Sum サブドキュメント配列をアンワインドして非正規化します。ユーザー エージェント名と値。
- グループと合計: $group パイプラインを使用してドキュメントをユーザー エージェント名でグループ化し、$sum 演算子を使用して対応する値を合計します。
- 独立したカウント フィールドの作成: 読みやすくするために、$group パイプライン内で三項演算子 ($cond) を使用して、「linux」と「ubuntu」用の独立したカウント フィールドを作成できます。
- パフォーマンスを向上させるための代替アプローチ: より効率的な代替方法として、少し異なる $group パイプラインを使用してユーザー エージェント数を集計し、名前でグループ化することができます。
最後にでは、mgo.Collection.Pipe() メソッドを使用して集計パイプラインを Go に変換し、MongoDB コレクションに対して実行します。これにより、指定されたユーザー エージェントと会場 ID に関連付けられた数を含むアイテムのリストが返されます。
以上がGo を使用して MongoDB の複数の会場にわたるユーザー エージェントの発生を効率的にカウントするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか?

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?
