前提・実現したいこと
rails c
で特定のアクションを実行したユーザーのみ、User.find(10).destroy
は出来るのに User.find(10).delete
が出来なくなりました。理由が分からず困っております。
アプリ内には投稿、投稿へのコメント、いいね、フォロー、メッセージ、通知などいくつかアクションがあるのですが、この内「メッセージ」でアクションを起こしたユーザーがなぜか delete
出来なくなる現象が起きております。
ユーザーを新規作成し何もアクションを起こす前であったり、コメント、いいね、フォローなどのアクションを起こした後に delete
を試みた場合は上手く削除されます。
delete
を試みると以下の様にエラーが出てしまいます。
User.find(10).delete User Load (0.6ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 10 LIMIT 1 User Destroy (3.8ms) DELETE FROM `users` WHERE `users`.`id` = 10 ActiveRecord::StatementInvalid: Mysql2::Error: Cannot delete or update a parent row: a foreign key constraint fails (`hoge_development`.`messages`, CONSTRAINT `fk_rails_273a25a7a6` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`)): DELETE FROM `users` WHERE `users`.`id` = 10 from C:/Ruby26-x64/lib/ruby/gems/2.6.0/gems/mysql2-0.5.3-x64-mingw32/lib/mysql2/client.rb:131:in `_query' Caused by Mysql2::Error: Cannot delete or update a parent row: a foreign key constraint fails (`hoge_development`.`messages`, CONSTRAINT `fk_rails_273a25a7a6` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`)) from C:/Ruby26-x64/lib/ruby/gems/2.6.0/gems/mysql2-0.5.3-x64-mingw32/lib/mysql2/client.rb:131:in `_query'
外部キーが邪魔をしているようなのですが…。
メッセージ機能は以前から既に完成しており、アクションを行ったユーザーであっても delete
出来ていたと思います。
最近編集した点で言いますと Active Storage を使用して画像を表示するようコードを書きましたので、そこが怪しいと思います(クラウドストレージは AWS S3 を使用しており、保存も表示も上手く出来ております)。
メッセージ機能の詳細
メッセージ機能のリレーションですが、User と Message テーブルが Room、Entry テーブルと言う中間テーブルと結びついています。
ユーザー詳細ページ(users/show.html.erb
)にある「チャットする」と言うボタンを押すと Entry と Room テーブルにレコードが作成され、チャットルームでメッセージを送ると Message テーブルにレコードが作成されます。
そして今回の delete
が出来なくなる不具合はこの「チャットする」と言うボタンを押した瞬間から発生しておりました。(尚、通知機能はほぼ全てのアクションに結びついておりますが、「チャットする」ボタンを押して Entry, Room を作成しただけでは通知テーブルにレコードは何も出来ないので、通知機能は犯人ではなさそうです。)
user.rb
# メッセージ機能に関して。最近は何もいじっておりません。 has_many :messages, dependent: :destroy has_many :entries, dependent: :destroy has_many :rooms, through: :entries # Active Storageに関して。最近追加致しました。 has_one_attached :image_name, dependent: :destroy has_one_attached :cover_image_name, dependent: :destroy
room.rb
# 最近は何もいじっておりません。 has_many :messages, dependent: :destroy has_many :entries, dependent: :destroy has_many :users, through: :entries
entry.rb
# 最近は何もいじっておりません。 belongs_to :user belongs_to :room has_many :messages, through: :room
message.rb
# 最近は何もいじっておりません。 belongs_to :user belongs_to :room has_one :entry, through: :room
コントローラやビューも全て載せますと長くなりますので、最近いじった rooms_controller.rb
のみ一旦記載致します。
rooms_controller.rb
# Active Storage 関連で発生する N+1問題を解消する為、最近編集致しました。 private def set_another_entries my_room_ids = @current_user.entries.pluck(:room_id) @another_entries = Entry.includes(:room, user: { image_name_attachment: :blob }) # この行を編集。 .where(room_id: my_room_ids).where('entries.user_id != ?', @current_user.id) @entries = @another_entries.includes(:messages).to_a .reject {|entry| entry.messages.blank?} .sort_by {|entry| entry.messages.order(created_at: :desc).first.created_at} .reverse end
その他外部キー関連で最近変わった事と言えば、Active Storage を使い始めた時点で以下の外部キーが同時に付いた事くらいです。
schema.rb
add_foreign_key "active_storage_attachments", "active_storage_blobs", column: "blob_id"
しかし一体何が原因で delete
が使えなくなったのか見当がつかないでおります…。
どなたかご助言を頂けますと有難いです。
補足情報(FW/ツールのバージョンなど)
ruby 2.6.8p205 (2021-07-07 revision 67951) [x64-mingw32]
RubyGems 3.0.3.1
Rails 5.2.6
mysql Ver 14.14 Distrib 5.7.36, for Win64 (x86_64)
回答1件
あなたの回答
tips
プレビュー