1

我正在搜索用户模型中的记录。搜索属性 from_date、to_date 将用于根据 created_at 列搜索用户模型中的记录。

User model : (id, name, created_at)

我在数据库中有以下记录。

id, name, created_at
 1   jd1    2013-09-04 18:01:57
 2   jd2    2013-09-05 19:01:57
 3   jd3    2013-09-05 23:01:57

当我搜索时,在 "2013-09-04".to_date(from_date) 和 "2013-09-05".to_date(to_date) 之间,只返回前两条记录。最后一个没有被退回。当我将 to_date 更改为“2013-09-06”时,最后一条记录正在显示。这是我使用的查询。

date_range = from_date ... to_date + 1.day
scope :by_date, ->(date_range) {where(created_at: date_range)}

User.by_date(date_range)

查询有什么问题?我认为它存在日光时区问题。

4

1 回答 1

1

您需要将 created_at 字段转换为日期:

CAST(users.created_at AS DATE)

在 where 子句中:

where("CAST(users.created_at AS DATE) BETWEEN ? AND ?", date1, date2 )

就您而言,在您的范围内:

scope :by_date, lambda{ |date_range| where("CAST(users.created_at AS DATE) BETWEEN ? AND ?", date_range.min, date_range.max ) }

希望这可以帮助!


奖励: CAST 的简短版本,可与 PostGre SQL 一起使用:

scope :by_date, lambda{ |date_range| where("users.created_at::date BETWEEN ? AND ?", date_range.min, date_range.max ) }
于 2013-09-06T18:10:11.667 回答