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

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

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

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

Q&A

解決済

1回答

1824閲覧

Railsでmigrateとするとカラム名は重複してないのに重複エラーが出る

umigame_Rails

総合スコア66

Ruby on Rails

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

1グッド

0クリップ

投稿2022/06/21 00:02

編集2022/06/21 00:21

環境は
Ruby:3.0.2
Rails:7.0.3
Cloud9
です
下記のようなマイグレーションファイルをrails db:migrateで実行するとエラーが出ます
名前は重複してないはずなんですけどこれはなぜなのでしょうか?
またどうすればこの「tweet_id」のまま使えますでしょうか?

Ruby

1class CreateComments < ActiveRecord::Migration[7.0] 2 def change 3 create_table :comments do |t| 4 5 6 t.string :image 7 t.integer :user_id 8 t.integer :tweet_id 9 t.text :body 10 t.references :tweet, null: false, foreign_key: true 11 t.timestamps 12 end 13 end 14end 15

エラー内容

== 20220620234356 CreateComments: migrating ===================================
-- create_table(:comments)
rails aborted!
StandardError: An error has occurred, this and all later migrations canceled:

you can't define an already defined column 'tweet_id'.
/home/ubuntu/environment/jisya_app/db/migrate/20220620234356_create_comments.rb:8:in block in change' /home/ubuntu/environment/jisya_app/db/migrate/20220620234356_create_comments.rb:3:in change'

Caused by:
ArgumentError: you can't define an already defined column 'tweet_id'.
/home/ubuntu/environment/jisya_app/db/migrate/20220620234356_create_comments.rb:8:in block in change' /home/ubuntu/environment/jisya_app/db/migrate/20220620234356_create_comments.rb:3:in change'
Tasks: TOP => db:migrate
(See full trace by running task with --trace)

a22r1345👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

名前は重複してないはずなんですけど

重複しています。t.references :tweettweet_idカラムを生成しますが、同名のカラムを作成する指定がすでになされています。

投稿2022/06/21 01:18

maisumakun

総合スコア145192

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

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

umigame_Rails

2022/06/21 01:26

ありがとうございます すでにtweetに紐づけしているからここでIDを管理するカラムを作る必要もないということですね
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問