5

我正在尝试逐步浏览使用 find_each 检索的记录列表。

我在这个堆栈溢出帖子中的答案上设计了我的控制器代码,但我仍然收到“No Block Given (Yield)”错误。

我刚刚开始使用 Ruby 和 Rails,我还没有找到一个完整的解释(尽管有很多基本的例子)块和产量,这给了我我需要的东西。

我的代码如下所示:

def select_save
    @class = params[:class]
    @student_id = params[:id]
    @class.each do |id|
      old_subject = Subject.find(id)
      new_subject = old_subject.dup
      new_subject.student_id = @student_id
      new_subject.save
      Assignment.find_each.where(:subject_id => id) do |assignments|
        assignments.each do |a|
          new_assignment = a.dup
          new_assignment.subject_id = new_subject.id
          new_assignment.save
        end
      end
    end

    respond_to do |format|
      format.html { redirect_to @student, :notice => 'Subject and assignments created.' }
    end
  end

并且错误指向带有 find_each 的行。

我知道我需要一个块来让步,但是在这种特殊情况下,这到底是怎么回事却让我无法理解。

感谢您的任何建议。

4

1 回答 1

5

您将一个块传递给where并且没有块传递给find_each. 你不能那样做。您需要反转find_eachwhere在这一行中,顺序很重要,因为块被传递给最后调用的方法:

Assignment.find_each.where(:subject_id => id) do |assignments|

它应该是:

Assignment.where(:subject_id => id).find_each do |assignments|

你的下一个问题是你试图迭代assignments,这是一个单一的分配。find_each已经在为您进行迭代,一次将一个分配传递到块中。该块应为:

Assignment.where(:subject_id => id).find_each do |assignment|
  new_assignment = assignment.dup
  new_assignment.subject_id = new_subject.id
  new_assignment.save
end

我将假设您的主题有很多作业,因为您的班级中有subject_id一个Assignment。如果是这种情况,编写循环的最终也是最正确的方法是:

old_subject.assignments.each do |assignment|
  new_assignment = assignment.dup
  new_assignment.subject_id = new_subject.id
  new_assignment.save
end
于 2012-08-15T04:30:55.703 回答