質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

DELETE

ファイルシステムからファイル、データベースからレコードを削除することまたはメモリ内のオブジェクトの割り当てを取り消すことをさします。もしくは、HTTPプロトコルのDELETEを指すこともあります。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

974閲覧

特定のアクションを実行したユーザーのみ、destroy は出来るものの delete が出来なくなる。

punchan36

総合スコア105

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

DELETE

ファイルシステムからファイル、データベースからレコードを削除することまたはメモリ内のオブジェクトの割り当てを取り消すことをさします。もしくは、HTTPプロトコルのDELETEを指すこともあります。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2021/12/12 01:55

前提・実現したいこと

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)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2021/12/12 02:45

なぜdestroyでなくdeleteしなければしけないのでしょうか?
punchan36

2021/12/12 03:01

ユーザーとその関連を削除したかっただけですので、destroy が出来る時点で目的は達成しております。 ただ試しに両方やってみた所 delete のみ出来ず、理由が分からずモヤモヤしてしまった為に質問致しました…。
guest

回答1

0

ベストアンサー

メッセージ機能は以前から既に完成しており、アクションを行ったユーザーであっても delete 出来ていたと思います。

これが単に勘違いだっただけ、ということはありませんか?

エラーメッセージを読む限りはFOREIGN KEY上、メッセージのあるユーザーは削除できなさそうです。

投稿2021/12/12 03:03

maisumakun

総合スコア146018

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

punchan36

2021/12/12 03:55

有難うございます! 確かに記憶に頼っておりますので、以前は確実に delete 出来ていたとは言い切れないです…。 考えてみればそうかもしれません。 コメント、いいね、フォローなどのアクションに関しては FOREIGN KEY は設定していない為 delete 出来る。メッセージ関係は 全テーブルに FOREIGN KEY を設定している為、中間テーブルであってもレコードが発生した時点で delete が出来なくなる。と言う事だったのだと思います。 以前は delete 出来ていたと思い込んでいた為、ついコードの異変探しから入ってしまいました。お騒がせしてしまいましたが、ご回答有難うございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問