0
class Article < ActiveRecord::Base
  attr_accessible :console, :ean, :title, :title_spaceless
  has_many :dealers, :through => :units
end

class Dealer < ActiveRecord::Base
  attr_accessible :adress, :name, :website
  has_many :articles, :through => :units
  validates :name, :uniqueness => { :case_sensitive => false }
end

class Unit < ActiveRecord::Base
  attr_accessible :article_id, :dealer_id, :note, :price
  belongs_to :article
  belongs_to :unit 
end

如何同时创建经销商、文章和单位?

我尝试的第一件事是这样的,但它似乎是完全错误的。

@dealer = Dealer.find_or_create_by_name("Surugaya")
@dealer.article.create(:title => game.content, :title_spaceless => game.content.delete(' '), :console => "SNES").unit.create(:article_id => @dealer.article.article_id, :units_id => @dealer.article.unit_id, :price => game.price) 
4

1 回答 1

1

首先,您在课堂units上缺少一个关联。Article你需要解决这个问题:

has_many :units

通过“同时”,我假设您的意思是在同一个数据库事务中。你可以试试这个:

Dealer.transaction do
  @dealer = Dealer.find_or_create_by_name("Surugaya")
  @article = @dealer.articles.create!(
      :title => game.content, 
      :title_spaceless => game.content.delete(' '), 
      :console => "SNES"
  )
  @unit = @article.units.create!(:price => game.price)
end
于 2013-01-01T22:49:00.573 回答