I'm trying to query the equivalent of this sql snippet using arel:
WHERE (("participants"."accepted" = 'f' AND "participants"."contact_id" = 1)
OR "participants"."id" IS NULL)
So I want (accepted && contact_id=1) OR NULL
Here's what I've got in AREL
participants[:accepted].eq(false).and(participants[:contact_id].eq(1).
or(participants[:id].is(nil)
Problem is, this generates:
("participants"."accepted" = 'f' AND "participants"."contact_id" = 1 OR "participants"."id" IS NULL)
Note the lack of parentheses around my and conditions. I believe that according to the operator precedence, that I'm getting:
accepted && (contact_id=1 OR NULL)
Adding parentheses in in the AREL query has no affect. Any thoughts?
I believe that according to the operator precedence
The problem is that AND has higher precedence than OR. So 1 AND 2 OR 3
is equivalent to (1 AND 2) OR 3
.
As a side note: if you use a wrapper like this one, you can write:
User.where((User[:created_at] > 3.days.ago) & (User[:enabled] == true))