登录
首页 >  Golang >  Go问答

利用MongoDB和Google Civil.Date包进行过滤器查询的步骤

来源:stackoverflow

时间:2024-02-16 13:18:24 412浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《利用MongoDB和Google Civil.Date包进行过滤器查询的步骤》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

问题内容

google 的 civil 软件包很简单 - 它的目标是代表一年中的某一天,而不考虑时间或地点。这对于诸如生日之类的事情很有用,因为世界各地的时间都相同 - 尽管世界各地的时间不同。

主要结构是:

type date struct {
    year  int        // year (e.g., 2014).
    month time.month // month of the year (january = 1, ...).
    day   int        // day of the month, starting at 1.
}

它在 mongodb 中表示为具有 3 个整数值的对象:

# golang definition
occurredOn civil.Date `bson:"occurredOn"`
...

# mongodb definition
occurredOn Object
year       2022
month      4
day        2

如果您想查询,这会导致奇怪的情况。例如,我不认为标准 $gt / $lt 查询将起作用,因为 2022-4-2 按字典顺序大于 2022-10-20 但是更早的日期,我相信 mongodb 可以为以下情况提供最佳情况相互比较对象,但这也增加了查询的内部复杂性。从本质上讲,它比比较 time.time 的两个实例要复杂得多。那么最简单的方法是什么?


正确答案


据我所知,有四种边缘情况需要涵盖:

  • 同一日期但不同年份
  • 同一日期但不同月份
  • 同一日期但不同的日子
  • 不同年/月/日的某种组合

这是我想出的函数,用于返回 mongodb 查询,以检查 civil.date 是否严格大于另一个 civil.date。对于奇怪的格式表示歉意,但这就是 go fmt 吐出的内容:

func occurredOnGTQueryTest(date civil.Date) bson.M {
    return bson.M{"$or": bson.A{
        bson.M{"occurredOn.year": bson.M{"$gt": date.Year}}, // happens in the next year

        bson.M{"occurredOn.year": bson.M{"$gte": date.Year},
            "occurredOn.month": bson.M{"$gt": date.Month}}, // happens in the next month

        bson.M{"occurredOn.year": bson.M{"$gte": date.Year},
            "occurredOn.month": bson.M{"$gte": date.Month},
            "occurredOn.day":   bson.M{"$gt": date.Day}}, // happens in the next day
    },
    }
}

今天关于《利用MongoDB和Google Civil.Date包进行过滤器查询的步骤》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>