当前正在维护一些旧的Ruby服务器,并在Log中收到以下错误:
NoMethodError (undefined method `find_all_by_X_ID' for #<Class:0x00000005555555>):
app/controllers/some_controller.rb:10:in `buggy_function'
当查看越野车功能代码中的错误行时,如下所示:
Hash[S.find_all_by_X_ID(TaskRun.select(:x_id).uniq.where(y_id: @y.Y_ID).map(&:x_id)).map { |s| [s.S_IDENTIFIER, s.X_ID] }]
坦率地说,我是Ruby的新手,想知道如何实现此find_all_by_X
查询是最好的,以及为什么它看起来应该是自动的(与模型组件有关)
我们正在研究Ruby版本2。
答案 0 :(得分:3)
find_all_by
在Rails 4中似乎已被弃用...
内部Rails使用method_missing实现了find_all_by_x_id
之类的方法(该方法实际上是通过元编程来动态定义的)……但是您不必为用例担心。
就您的代码而言,如果我们将x_ids列表提取到变量中:
x_ids = TaskRun.select(:x_id).uniq.where(y_id: @y.Y_ID).map(&:x_id)
然后您需要重写以下行:
S.find_all_by_X_ID(x_ids)
您可以将其重写为:
S.where(x_id: x_ids)