Rails с ошибкой после создания новой таблицы - PullRequest
0 голосов
/ 28 мая 2018

(извините за мой английский) Здравствуйте, я создаю новый пост для моей ошибки, чтобы более четко объяснить, что случилось, я добавил таблицу "user-actions", которая позволяет мне узнать, видел ли пользователь действие или нет. Вотпредставление моей БД

DB Моя проблема заключается в том, что я не могу больше создавать статью. Очевидно, проблема появляется в сохранении:

Журналы:

Started POST "/activities" for 127.0.0.1 at 2018-05-24 17:21:49 +0200
Processing by ActivitiesController#create as JS
  Parameters: {"utf8"=>"✓", "authenticity_token"=>"Cq573getfK9HBo4U9xiftsdtmScb08A28AWCcwTq2+Csn7u2hmylpjMdaB5qtJ6ZfWoHV/TZ+zF0xtgPCCp69Q==", "activity"=>{"title"=>"Activity 1 ", "content"=>"<p>dzdzqdqzdqz</p>", "group_id"=>"2"}, "commit"=>"Créer l'activité"}
  User Load (4.6ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT $2  [["id", 2], ["LIMIT", 1]]
  ↳ /home/benjamin/.rbenv/versions/2.5.0/lib/ruby/gems/2.5.0/gems/activerecord-5.2.0.rc1/lib/active_record/log_subscriber.rb:98
   (0.2ms)  BEGIN
  ↳ app/controllers/activities_controller.rb:9
  Group Load (2.3ms)  SELECT  "groups".* FROM "groups" WHERE "groups"."id" = $1 LIMIT $2  [["id", 2], ["LIMIT", 1]]
  ↳ app/controllers/activities_controller.rb:9
   (0.2ms)  ROLLBACK
  ↳ app/controllers/activities_controller.rb:9
Redirected to http://localhost:3000/
Completed 200 OK in 19ms (ActiveRecord: 7.4ms)

#activities_controller.rb:9 =>     if @activity.save

Контроллер:

  def create
    @activity = Activity.new(activity_params)
    @activity.user = current_user
    if @activity.save
      flash[:notice] = "Votre activité a été créée !"
      redirect_to root_path
    else
      flash[:alert] = "Erreur lors la création"
      redirect_to root_path
    end
  end

контроллер не изменился, когда я добавляю новую таблицу, и форма для создания нового действия не содержит ошибки (идентификатор группы / пользователь IS / content / title /дата и т. д. действительны)

изменились мои модели:

ДО

Модель деятельности:

class Activity < ApplicationRecord
  belongs_to :user
  belongs_to :group
  validates :content, presence: true
end

модель пользователя:

class User < ApplicationRecord
  rolify
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
  has_many :user_groups
  has_many :activities
end

ПОСЛЕ:

Модель деятельности:

class Activity < ApplicationRecord
  has_many :user_activities, dependent: :destroy
  has_many :users, through: :user_activities
  belongs_to :user, class_name: 'User'
  belongs_to :group
  validates :content, presence: true
end

Модель активности пользователя:

class UserActivity < ApplicationRecord
  belongs_to :activity
  belongs_to :user    
end

Модель пользователя:

class User < ApplicationRecord
  rolify
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
  has_many :user_groups
  has_many :user_activities
  has_many :activities, through: :user_activities

end

Спасибо :)

1 Ответ

0 голосов
/ 28 мая 2018

Во время разработки может потребоваться заменить как @activity.save на @activity.save! и получить исключение с более подробной информацией об ошибке, которую вы имеете.

...