2

我正在使用rails,并且我想使用arel 来执行此sql 查询。

"SELECT `people`.* FROM `peoples`  WHERE `peoples`.`home_id` = 289 AND (`people`.`created_at` BETWEEN '2013-03-12' AND '2013-03-15' AND (`people`.`first_name` LIKE '%jane%' OR `people`.`email` LIKE '%jane%'))"

现在,我已经用 arel 解决了查询,但我想避免为必须匹配相同搜索变量的属性重复“matches("%#{search}%")”。

a.where(a.arel_table[:created_at].in(date_range).and(a.arel_table[:first_name].matches("%#{search}%").or(a.arel_table[:email].matches("%#{search}%"))))

就像是:

a.where(a.arel_table[:created_at].in(date_range).and([:email, :first_name].each {|attr| or.(a.arel_table[:attr].matches("%#{search}%"))))

但这不起作用。

4

1 回答 1

2

问题是条件看起来像 (((c1 or c2) or c3) or c4) 但似乎 Arel 的“或”概念是二元的。

所以不可能将它们定义为(c1 或 c2 或 c3 或 c4)。

于 2013-04-24T12:34:39.403 回答