mgo を使用して Go で MongoDB の日付範囲をクエリする方法は?

Linda Hamilton
リリース: 2024-11-05 15:47:02
オリジナル
496 人が閲覧しました

How to Query MongoDB Date Range in Go with mgo?

Go で mgo を使用して MongoDB の日付範囲をクエリする

MongoDB を使用する場合、日付範囲に基づいてドキュメントをクエリするのは一般的な操作です。この記事では、Go 用 MongoDB ドライバーである mgo を使用してそのようなクエリを実行する方法について説明します。

問題:

product のフィールドを持つ「my_sales」という名前の MongoDB コレクションがあります。品名、価格、発売日。 Go と mgo を使用して、特定の日付範囲内のすべての販売レコードを取得する必要があります。

解決策:

mgo は、time.Time 型を使用した日付のクエリをサポートしています。したがって、次のドキュメント構造を持つ例の場合:

<code class="go">type Sale struct {
    ProductName string    `bson:"product_name"`
    Price       int       `bson:"price"`
    SaleDate    time.Time `bson:"sale_date"`
}</code>
ログイン後にコピー

指定された日付範囲内の売上高をクエリするには、次のコードを使用できます:

<code class="go">package main

import (
    "context"
    "fmt"
    "log"
    "time"

    "gopkg.in/mgo.v2"
    "gopkg.in/mgo.v2/bson"
)

func main() {
    // Connect to MongoDB
    session, err := mgo.Dial("localhost:27017")
    if err != nil {
        log.Fatal(err)
    }
    defer session.Close()

    // Get a collection
    c := session.DB("my_db").C("my_sales")

    // Define the date range
    fromDate := time.Date(2014, time.November, 4, 0, 0, 0, 0, time.UTC)
    toDate := time.Date(2014, time.November, 5, 0, 0, 0, 0, time.UTC)

    // Query the collection
    results := []Sale{}
    err = c.Find(
        bson.M{
            "sale_date": bson.M{
                "$gt": fromDate,
                "$lt": toDate,
            },
        }).All(&results)
    if err != nil {
        log.Fatal(err)
    }

    // Print the results
    for _, sale := range results {
        fmt.Println(sale)
    }
}</code>
ログイン後にコピー

bson を指定することにより、 .M マップに適切な日付範囲基準を指定すると、指定した日付の間に発生したすべての売上を取得できます。

以上がmgo を使用して Go で MongoDB の日付範囲をクエリする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート