0

我有一个模型(事件),有五年的记录(每天一条记录)。我需要一种方法,当传递诸如 2011-12-25 00:00:00 之类的日期对象时,将向我显示 12/25 发生的所有记录(查询 :created_at 列),无论年份如何或过去的时间。

我尝试了以下查询来检索给定日期之间的数据,但是在一年更改后我遇到了一个问题,我的查询无法检索记录。例如记录 sdate="1-06-2013" 和 edate ="2-2-2014" 我想要 1 月 1 日的记录,那么我怎样才能获得这些数据。

db.events.find("this.sdate.getMonth() > 6 && this.edate.getMonth() < 6");

我需要在 Mongoid 而不是 ActiveRecord 中使用精确的以下查询

Model.where("MONTH(created_at) = ? and DAY(created_at) = ?", somedate.month, somedate.day)

4

2 回答 2

2

编辑:(我的第一个答案错过了它应该忽略年份和时间的事实)

像这样使用聚合管道:

project = { '$project' => { 
              'day' => { '$dayOfMonth' => '$created_at' },
              'month' => { '$month' => '$created_at' }
            }
          }
match = { '$match' => { 'day' => 25, 'month' => 12 } }

Events.collection.aggregate([project, match])

这应该会返回一个哈希数组,其中包含预计的日期和月份值以及匹配事件的 _id。然后,您可以将它们映射回事件或您需要对它们执行的任何操作。

于 2013-09-20T13:35:14.217 回答
0

你可以尝试做一些Javascripting查询

db.mydatabase.mycollection.find({$where : 'return this.date.getMonth() == 11'})

但我永远不会这样做。我要做的是将月日存储在一个字段中,在上面有一个索引,并有一个更快的查询。否则你将扫描所有的dos。

于 2013-09-17T21:09:16.550 回答