0

http://railscasts.com/episodes/17-habtm-checkboxes-revised?view=asciicastチュートリアルに従って、関係を介して has_many を設定しました。あるモデルから情報にアクセスしようとすると、機能しますが、他のモデルからは機能しません。

@product.category_idsとを介して Product モデルからカテゴリ情報にアクセスできます@product.categoriesが、その逆は当てはまりません。Category モデルから製品情報にアクセスできません。@category.product_idsorを使用@category.productsするとエラーが発生するNoMethodError: undefined method 'product_ids' for #<Category:0x007fa70d430e98>

Product.rb

class Product < ActiveRecord::Base
  attr_accessible  :category_ids

  has_many :categorizations
  has_many :categories, through: :categorizations
  accepts_nested_attributes_for :categorizations,  :allow_destroy => true
end

カテゴリー.rb

class Category < ActiveRecord::Base
  attr_accessible  :product_ids

  has_many :categorizations
  has_many :products, through: :categorizations
end

- 編集 -

スキーマ.rb

ActiveRecord::Schema.define(:version => 20130926192205) do

  create_table "categories", :force => true do |t|
    t.string   "name"
    t.datetime "created_at",     :null => false
    t.datetime "updated_at",     :null => false
  end

  create_table "products", :force => true do |t|
    t.string   "name"
    t.datetime "created_at",          :null => false
    t.datetime "updated_at",          :null => false
  end

  create_table "categorization", :force => true do |t|
    t.integer  "product_id"
    t.integer  "category_id"
    t.datetime "created_at",     :null => false
    t.datetime "updated_at",     :null => false
  end

  add_index "categorization", ["product_id", "category_id"], :name => "index_categorization_on_product_id_and_category_id", :unique => true
  add_index "categorization", ["product_id"], :name => "index_categorization_on_product_id"
  add_index "categorization", ["category_id"], :name => "index_categorization_on_category_id"

end
4

1 に答える 1

0

各オブジェクトからレコードにアクセスするには、次のことができる必要があります。

@category.products

@product.categories

これにより、関連付けられたオブジェクトが得られます。

product_idsはカテゴリの属性ではなく、accepts_attributes_for :productsカテゴリ モデルと似ていないため、削除attr_accessible :product_idsするとエラーが修正されます。

于 2013-09-26T21:01:24.897 に答える