初学者です。
データベースのカラム名を変更しようと思い、
https://qiita.com/kaito-chiba/items/723da8627438b67cc02c
を参考に、カラム名を変更しました。
その後、挙動を確認したところ、
ActiveRecord::InvalidForeignKey in KarutesController#create Mysql2::Error: Cannot add or update a child row: a foreign key constraint fails (`amollir_new_development`.`karutes`, CONSTRAINT `fk_rails_f31fca33d2` FOREIGN KEY (`patient_id`) REFERENCES `users` (`id`))
https://gyazo.com/279f61d9be92fa3536b3411b14186686
のエラーが出ました。
外部キーのカラムを置き換えたのが問題だと気付き
https://dev.mysql.com/doc/refman/5.6/ja/create-table-foreign-keys.html
上記を参考にカラムの削除を行おうと
ALTER TABLE karutes DROP FOREIGN KEY user_id;
を実行したところ、
ERROR 1005 (HY000): Can't create table '#sql-4fc_99f' (errno: 13)
のエラーが発生しました。
このエラーの原因がわからなかったため、一度置き換えたカラム名を元の状態に戻そうと思い、
rails db:rollback
を実行しましたが、実行できなかったため
rails db:migrate:reset
を行いました。
その後、
rails db:migrate
を実行しましたが、
SepuelProの画面から全てのテーブル表示されていないままです。
https://gyazo.com/4f230549066c8f5a99feef203349ea47
この原因について調べましたが、自分の調べ方が悪いのか、解決方法がわかりませんでした。
解決方法をご教示いただければと思います。
よろしくお願いいたします。
###参考事項
関係あるかわかりませんが、念のため記載させていただきます。
一度ローカルサーバーを再起動したのち、ローカルサーバーの挙動を確認したところ、今までのデータは表示されている状況です。
###ソースコード
20210115062711_create_karutes.rb class CreateKarutes < ActiveRecord::Migration[6.0] def change create_table :karutes do |t| t.text :pain t.text :illness t.text :history t.text :medicine t.text :habit t.text :memo t.date :date t.references :user, foreign_key: true t.timestamps end end end
20210122092705_rename_titre_column_to_karutes.rb class RenameTitreColumnToKarutes < ActiveRecord::Migration[6.0] def change rename_column :karutes, :user_id, :patient_id end end
↑こちらはリネームのファイルの名前を間違えて実行してしまいました。
回答1件
あなたの回答
tips
プレビュー