🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby

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

Ruby on Rails

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

Q&A

解決済

1回答

1922閲覧

rails db:migrate:resetした後、rails db:migrateを実行できていない

noe.black

総合スコア2

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2021/01/22 13:07

編集2021/01/22 13:10

初学者です。

データベースのカラム名を変更しようと思い、
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

↑こちらはリネームのファイルの名前を間違えて実行してしまいました。

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

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

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

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

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

siruku6

2021/01/22 13:27

>ローカルサーバーの挙動を確認したところ、今までのデータは表示されている状況です。 ということであれば、DBにテーブルが作成されているような気がします。 $ rails db:migrate:status を実行すれば、どのmigrationファイルが実行済みなのかを確認することができます。 up→実行済み down→未実行(適用されていない) また、データベースに直接ログインすれば各種テーブルがあるかどうかは確認できますよね? その結果はいかがでしたか? 印象としては、「SepuelPro」の誤作動やバグを疑っています。
noe.black

2021/01/22 13:40

siruku6様 コメントありがとうございます。rails db:migrate:statusを確認したところ全てupとなっています。 SepuelProの問題であると仮定し、一度再インストールしようと試みました。 brew cask uninstall sequel-pro のコマンドを実行したところ、 Error: Calling brew cask uninstall is disabled! Use brew uninstall [--cask] instead. のエラーが出てしまいましたが、こちらは関係があるのでしょうか?
siruku6

2021/01/22 13:42

申し訳ないのですが、Macユーザーではないのでそちらの問題の対処法はわからないです...
noe.black

2021/01/22 13:45

siruku6様 ありがとうございます。 自分も現在調べています。 貴重なアドバイスありがとうございました。
siruku6

2021/01/23 06:19

解決したようでよかったです!
guest

回答1

0

自己解決

mysqlの管理権限を誤操作で外していたことが、原因の現象だったとのことで、管理権限を自分に戻すようにしたところ解決しました。

コメントいただいたsiruku6様。この度はありがとうございました。

投稿2021/01/23 02:26

noe.black

総合スコア2

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問