【问题标题】:Build an ActiveRecord query with multiple conditional clauses使用多个条件子句构建 ActiveRecord 查询
【发布时间】:2015-08-25 23:36:11
【问题描述】:

使用 ActiveRecord,您可以像这样构建查询:

query = MyModel.where(value_one: true)
if (condition)
  query.where(value_two: true)
else
  query
end

但是,当有多个条件时,我遇到了问题:

query = MyModel.where(value_one: true)
query.where(value_two: true) if condition_two
query.where(value_three: true) if condition_three
query

在这种情况下,它只会检查value_one 是否为真。有趣的是,如果我:

query = MyModel.where(value_one: true)
query.where(value_two: true)
query.where(value_three: true)

然后它会检查value_onevalue_three 是否为真,而不是value_two。任何人都明白这是为什么以及如何让查询子句正确地建立在彼此之上?

【问题讨论】:

    标签: ruby-on-rails activerecord


    【解决方案1】:

    当您链接查询或范围时,ActiveRecord 返回另一个带有附加条件的 Relation 对象;它不会修改原始对象。要修改关系,您需要链接查询并分配结果,例如:

    query = MyModel.where(value_one: true)
    query = query.where(value_two: true) if condition_two
    query = query.where(value_three: true) if condition_three
    query
    

    请注意,在您尝试提取数据之前,查询不会真正执行,无论是通过to_seach 等。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-06-03
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多