您好我有一个名为" my_sales"有字段product_name,price,sale_date。
我的文档看起来像
{
"_id" : ObjectId("5458b6ee09d76eb7326df3a4"),
"product_name" : product1,
"price" : 200,
"sale_date" : ISODate("2014-11-04T11:22:19.589Z")
}
{
"_id" : ObjectId("5458b6ee09d76eb7326df3a4"),
"product_name" : product1,
"price" : 200,
"sale_date" : ISODate("2014-11-04T11:22:19.589Z")
}
{
"_id" : ObjectId("5458b6ee09d76eb7326df3a4"),
"product_name" : product1,
"price" : 200,
"sale_date" : ISODate("2014-11-04T11:22:19.589Z")
}
{
"_id" : ObjectId("5458b6ee09d76eb7326df3a4"),
"product_name" : product1,
"price" : 200,
"sale_date" : ISODate("2014-11-05T11:22:19.589Z")
}
我试过像这样的mongo shell
db.my_sales.find({ sale_date: { $gt: ISODate("2014-11-04"), $lt: new ISODate("2014-11-05") });
它给出了正确的结果。现在我需要使用golang查询相同的内容 我试过这个
var sales_his []Sale
err := c.Find(bson.M{"sale_date":bson.M{ "$gt": "ISODate("+date_from+")", "$lt": "ISODate("+date_to+")" } }).All(&sales_his)
给出null结果请帮助
答案 0 :(得分:29)
mgo支持time.Time了解BSON日期。
所以如果你的结构看起来像这样:
type Sale struct {
ProductName string `bson:"product_name"`
Price int `bson:"price"`
SaleDate time.Time `bson:"sale_date"`
}
然后你可以像这样查询:
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)
答案 1 :(得分:0)
我有新方法来查询日期范围:
// convert to date
fromTime := time.Unix(1509358405981/1000, 0)
// Convert date to ObjectID with time
fromObjectBson := bson.NewObjectIdWithTime(fromTime)
// condition
bson.M{"_id":bson.M{"$gt": fromObjectBson}}
这会加快您的查询速度。
答案 2 :(得分:-1)
您也可以检查一下。如果您使用的是这种方法,请使用parse:
db.getCollection('user').find({
createdOn: {
$gt: ISODate("2020-01-01T00:00:00.000Z"),
$lt: ISODate("2020-03-01T00:00:00.000Z")
}
})
无需解析的功能:使用字符串获取值
db, err := GetDB()
if err != nil {
return nil, err
}
defer db.Session.Close()
var date []models.User
coll := db.C(constants.USERTABLE)
findQuery := bson.M{"createdOn": bson.M{"$gt": echo.FromDate, "$lt": echo.ToDate}}
shared.BsonToJSONPrint(findQuery)
err = coll.Find(findQuery).All(&date)
if err != nil {
return nil, err
}
return date, nil
}