Maison > développement back-end > Golang > le corps du texte

Comment interroger une collection MongoDB avec une plage de dates à l'aide de Mgo et Go ?

Patricia Arquette
Libérer: 2024-11-08 01:57:02
original
838 Les gens l'ont consulté

How to Query a MongoDB Collection with a Date Range Using Mgo and Go?

Interrogation de MongoDB avec une plage de dates à l'aide de Mgo et Go

Vous avez rencontré un problème lors de l'interrogation d'une collection MongoDB avec une plage de dates à l'aide de l'option Bibliothèque Mgo dans Go. Votre requête ne renvoie pas les résultats attendus, bien qu'elle fonctionne correctement dans le shell MongoDB.

Pour résoudre ce problème, envisagez la solution suivante :

Gestion des valeurs de date/heure dans Go

Mgo prend en charge time.Time pour la gestion des dates BSON. Dans votre structure Go, définissez le champ SaleDate comme suit :

<code class="go">type Sale struct {
    ProductName string    `bson:"product_name"`
    Price       int       `bson:"price"`
    SaleDate    time.Time `bson:"sale_date"`
}</code>
Copier après la connexion

Construction de la requête

Une fois votre structure définie, vous pouvez construire la requête en utilisant bson. M :

<code class="go">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)

var sales_his []Sale
err = c.Find(
    bson.M{
        "sale_date": bson.M{
            "$gt": fromDate,
            "$lt": toDate,
        },
    }).All(&sales_his)</code>
Copier après la connexion

Dans cette requête, nous utilisons les opérateurs $gt et $lt pour spécifier la plage de dates. Les variables fromDate et toDate sont de type time.Time.

En implémentant ces modifications, vous devriez pouvoir interroger avec succès votre collection MongoDB avec une plage de dates à l'aide de Mgo et Go.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!