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 サイトの他の関連記事を参照してください。