Zapytanie, które chcesz zbudować to:
MyClass.where(
:name.in => [ 'John', 'Luke' ],
:status.in => [ 'ACTIVE', 'SUSPENDED' ]
)
:field.in
działa tak samo jak field in (...)
w SQL, a to tylko krótka forma wyrażenia lub. To znacznie ułatwia sprawę, ponieważ wystarczy dodać .in
wywołuje criteria
klucze, których wartości są tablicami, coś takiego:
query = criteria.each_with_object({}) do |(field, values), query|
field = field.in if(values.is_a?(Array))
query[field] = values
end
MyClass.where(query)