1
class Job < ActiveRecord::Base    
has_many :employments, :dependent => :destroy
has_many :users, :through => :employments

class User < ActiveRecord::Base
has_many :employments 
has_many :jobs, :through => :employments

class Employment < ActiveRecord::Base
belongs_to :job
belongs_to :user  # Employment has an extra attribute of confirmed ( values are 1 or 0)

在我看来,我正在尝试在用户单击时将已确认的字段从 0 更新为 1。

<%= link_to "Confirm Job", :action => :confirmjob, :id => job.id %>

在我的工作控制器中,我有

def confirmjob
  @job = Job.find(params[:id])
  @job.employments.update_attributes(:confirmed, 1)
  flash[:notice] = "Job Confirmed"
  redirect_to :dashboard
end

我确信这都是错误的,但我似乎在猜测 has_many: through。我将如何更新连接表中的已确认字段?

4

2 回答 2

2

我认为工作被就业分配给用户。因此,正如 Joel 所建议的那样,更新所有工作并不是一个好主意。我会推荐这个:

class Employment
  def self.confirm!(job)
    employment = Employment.find(:first, :conditions => { :job_id => job.id } )
    employment.update_attribute(:confirmed, true)
  end
end

从你的控制器

@job = Job.find(params[:id])
Employment.confirm!(@job)

这意味着一项工作只能由一个用户承担。

于 2009-10-05T05:49:32.583 回答
0

这是一个尝试(未经测试):

def confirmjob
  @job = Job.find(params[:id])
  @jobs.employments.each do |e|
    e.update_attributes({:confirmed => 1})
  end
  flash[:notice] = "Job Confirmed"
  redirect_to :dashboard
end
于 2009-10-05T03:09:02.773 回答