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

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

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

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

MySQL

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

Ruby on Rails

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

解決済

Mysql2::Error: Duplicate column name を解消したい

ntk__7__ksn
ntk__7__ksn

総合スコア14

Ruby

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

MySQL

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

Ruby on Rails

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

3回答

0グッド

0クリップ

4453閲覧

投稿2020/08/01 18:29

編集2020/08/02 05:58

#前提・実現したいこと
publisher_idカラムが重複してしまっているとの事。

######関係しているかは分からないですが今起こっている事です。
↓↓↓
userマイグレーションファイルはあるのにuserテーブルは反映されていない。
rails cができない。

######バージョン
ruby '2.6.6'
gem 'rails', '> 6.0.3', '>= 6.0.3.2'
gem 'mysql2', '
> 0.4.2'

#発生している問題・エラーメッセージ
ターミナルに出たエラー↓

-- add_reference(:books, :publisher, {:foreign_key=>true}) rails aborted! StandardError: An error has occurred, all later migrations canceled: Mysql2::Error: Duplicate column name 'publisher_id' /Users/7tk/projects/books-management/db/migrate/20200731052741_add_publisher_id_to_books.rb:3:in `change' /Users/7tk/projects/books-management/bin/rails:9:in `<top (required)>' /Users/7tk/projects/books-management/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Caused by: ActiveRecord::StatementInvalid: Mysql2::Error: Duplicate column name 'publisher_id' /Users/7tk/projects/books-management/db/migrate/20200731052741_add_publisher_id_to_books.rb:3:in `change' /Users/7tk/projects/books-management/bin/rails:9:in `<top (required)>' /Users/7tk/projects/books-management/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Caused by: Mysql2::Error: Duplicate column name 'publisher_id' /Users/7tk/projects/books-management/db/migrate/20200731052741_add_publisher_id_to_books.rb:3:in `change' /Users/7tk/projects/books-management/bin/rails:9:in `<top (required)>' /Users/7tk/projects/books-management/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Tasks: TOP => db:migrate (See full trace by running task with --trace)

localhost:3000でブラウザに出たエラー↓

StandardError An error has occurred, all later migrations canceled: Mysql2::Error: Duplicate column name 'publisher_id'

#該当のソースコード
どれか分からなかったのでいくつか載せました。
該当してそうなものを載せました。

class CreateBooks < ActiveRecord::Migration[6.0] def change create_table :books do |t| t.string :name t.date :published_on t.integer :price t.timestamps end end end
class AddPublisherIdToBooks < ActiveRecord::Migration[6.0] def change add_reference :books, :publisher, foreign_key: true change_column :books, :publisher_id, :integer, null: false end end

反映されていないuserマイグレーションファイル
↓↓↓

class CreateUsers < ActiveRecord::Migration[6.0] def change create_table :users do |t| t.string :name t.string :password t.string :email t.timestamps end end end

#自分で調べたことや試したこと
以前、重複しているものをコピーして一度消し、rails db:migrateをすると上手くいっていたのですが今回もそれをしたところ解決できませんでした。

他にも検索して出て来たものは試しました。

わかる方がいらっしゃいましたらよろしくお願いします。

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

Orlofsky

2020/08/01 22:36

誤解を避ける為、タイトルを Mysql2::Error: Duplicate column name を解消したい とでも修正されては? エラーメッセージは翻訳しないでそのまま提示できた方が適切なコメントが付き易いし、ググってこの質問を見つけた人にも役にたちます。
ntk__7__ksn

2020/08/02 05:58

コメントありがとうございます。 修正しました。

回答3

2

AddPublisherIdToBooks この前に table books にすでに publisher_idを作っていませんか?
そこへ add_reference :books, :publisher, でまた publisher_id を作ろうとしているので Duplicate column name 'publisher_id' となります。
booksにpublisher_idがあり、integerなら既に referenceしています。
integerでないなら change_column してください。
foreign_key にしたいなら、add_foreign_key(from_table, to_table, **options) してください。

投稿2020/08/02 02:36

winterboum

総合スコア22577

gouf, ntk__7__ksn👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

ntk__7__ksn

2020/08/02 06:37 編集

コメントありがとうございます。 booksテーブルに publisher_idを作っていました。 change_column :books, :publisher_id, :integer, null: false の部分をrake db:rollbackし消すという事ですか?

1

Mysql2::Error: Duplicate column name 'publisher_id'

publisher_id というカラム名が重複していると怒られています。
エラーメッセージの

Mysql2::Error: Duplicate column name

でググると、最初に
[エラー解決] Error: Duplicate column name ''"、カラムの重複、SQL がhitします。

投稿2020/08/01 22:08

Orlofsky

総合スコア16248

ntk__7__ksn👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

ntk__7__ksn

2020/08/02 06:25 編集

コメントありがとうございます。 こちらの記事は拝見し、publisher_idのカラムが書いてあるところを消したりマイグレーションファイルに書いてあるものを全て消してmigrateを実行してみたりしたのですが上手くいかなくできませんでした。 私の消す場所が違うのかよく分からなくなってしまったので質問してみようと思いました。
Orlofsky

2020/08/02 07:59

試した事も最初に質問に載せるべきでしたね。 次回からちょっとステップアップした質問にしましょうね。
ntk__7__ksn

2020/08/02 08:11

はい、頑張ります ! ありがとうございました。

0

自己解決

本屋行って色々探してみたところ、
既存のデータがあるのに外部キー制約を追加しようとすると追加した外部キー制約と不具合が発生してしまうとの事でした。
その為、外部キー制約を書いたら一度

rails db:reset ```をしてまた

rails db:migrate

それをやってみたら上手くlocalhost:3000にも接続できました。

投稿2020/08/02 07:01

ntk__7__ksn

総合スコア14

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Ruby

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

MySQL

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

Ruby on Rails

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