модель не создастся, потому что не может найти ID в Rails - PullRequest
1 голос
/ 09 марта 2011

У меня есть две модели.

class User 
  has_one  :spec, :dependent => :destroy

    # returns true for a duplicat record
       def duplicate?
         user = User.find_by_email(email)
         self.id = user.id unless user.nil?  
         not user.nil?
       end


  class Spec
  belongs_to :user

  validate_uniqueness_of :user_id

Controller

if @user.duplicate? || @user.save

 @user.create_spec(:birthdate => params[:user][:deliver_on])

end

Это приводит к следующей ошибке:

ActiveRecord::StatementInvalid in BoardController#new

Mysql::Error: Column 'user_id' cannot be null: INSERT INTO `specs` (`created_at`, `birthdate`, `updated_at`, `avatar`, `gender`, `user_id`, `last_name`, `first_name`, `picture`) VALUES('2011-03-09 05:43:46', NULL, '2011-03-09 05:43:46', '../images/default_avatar.jpg', NULL, NULL, '', '', NULL)

Однако, если я сделаю это:

@user.create_spec(:user_id => @user, :birthdate => params[:user][:deliver_on])

это работает!

Я думал, что выполнение @ user.create_spec предоставит user_id автоматически.

В любом случае, чтобы заставить эту работу работать так, как она должна? Я ценю любые отзывы. Спасибо

1 Ответ

1 голос
/ 09 марта 2011

Я думаю, что у вас неправильный подход.По вашему мнению,

class User 
  has_one :spec
end

Но вы создаете еще одну спецификацию для дублированного пользователя.Поэтому я предлагаю следующую ссылку.

http://www.hackerdude.com/2005/11/28/one-to-one-relationships-with-rails/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...