Использование ActiveRecord.create с ассоциативными принадлежностями - PullRequest
0 голосов
/ 19 сентября 2011

Я использую Rails 3.1 и имею простой класс транзакций, который ссылается на модель User:

class User < ActiveRecord::Base
   has_many :transactions, :foreign_key => 'sender_id'
end

class Transaction < ActiveRecord::Base
   belongs_to :sender, :class_name => 'User'
   belongs_to :recipient, :class_name => 'User'
   attr_accessible :amount
end

Схема базы данных

create_table "transactions", :force => true do |t|
   t.decimal "amount"
   t.integer "sender_id", :null => false
   t.integer "recipient_id", :null => false
end

create_table "users", :force => true do |t|
end

Я хотел бы создать набор начальных транзакций в seeds.rb, но базовый INSERT никогда не генерируется с внешними ключами для sender_id и recipient_id. Подпись метода:

ruby-1.9.2-p290 :022 >   Transaction.method(:create) => 
   #<Method: Transaction(id: integer, 
                         amount: decimal,
                         sender_id: integer,
                         recipient_id: integer)
   (ActiveRecord::Base).create> 

Я пробовал оба

Transaction.create(
  amount:                0.50,
  sender:                User.first,
  recipient:             User.last,
)

и

Transaction.create(
  amount:                0.50,
  sender_id:             User.first.id,
  recipient_id:          User.last.id,
)

В каждом случае оператор INSERT равен

SQL (0.6ms)  INSERT INTO `transactions` (`amount`, `recipient_id`, `sender_id`) 
             VALUES (0.75, NULL, NULL)

Я новичок в рельсах, так что я уверен, что это недоразумение с моей стороны, но я не смог найти решение, прочитав документацию по рельсам.

1 Ответ

2 голосов
/ 19 сентября 2011

Простое решение. Мне просто нужно было изменить строку attr_accessible в модели транзакции на

attr_accessible :amount, :sender, :recipient

и все хорошо.

...