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

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

ただいまの
回答率

90.51%

  • Ruby

    8988questions

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

  • Ruby on Rails

    8397questions

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

  • Ruby on Rails 5

    2806questions

  • SQLite

    750questions

    SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

rails db:migrateができない

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 890

nuasKent

score 10

 概要

いつもお世話になります。
この度、 RailsTutorial 14章を進行中にローカルのSQliteのDBにてrails db:関連で躓いてしまいました。
エラーメッセージは以下の通りです。

エラーメッセージ

SQLite3::SQLException: table "microposts" already exists
/Users/nasa/Gdrive_r75rid/local_document/Ruby/environment/tumatter_app/vendor/bundle/ruby/2.3.0/gems/sqlite3-1.3.13/lib/sqlite3/database.rb:91:in `initialize'

 試したこと

ここで、"microposts"テーブルが存在しているのにrails db:migrateで更に"microposts"をCreateしようとしているので怒られているのかと思い、stack overflowのこちらの記事を参考にmicopostsのdrop migrationを生成しrails db:migrateを試みたのですが、やはり同じエラー内容で怒られてしまいます。

 思い当たる節

  1. デフォルトのDB指定はdevelopです。
    ただmigrateをした際に、rais db:migrate RAILS_ENV=testをしてね!とたまに怒られていたので実行していました。このDBの環境指定なのか

  2. 14章に入った直後にユーザーのfollow関係を定義するmigrateをしたのですが、DBがおかしいと気づき、ブランチの変更内容を全てcheckoutしたのが原因なのか

 関連ファイル

  • db/migrate/20180829203429_create_microposts.rb
class CreateMicroposts < ActiveRecord::Migration[5.1]
  def change
    create_table :microposts do |t|
      t.text :content
      t.references :user, foreign_key: true

      t.timestamps
    end
    # 1つの配列に2つのキーを同時に扱う複合キーインデックスを作成
    add_index :microposts, [:user_id, :created_at]
  end
end
  • db/migrate/20180901051251_add_picture_to_microposts.rb
class AddPictureToMicroposts < ActiveRecord::Migration[5.1]
  def change
    add_column :microposts, :picture, :string
  end
end
  • db/migrate/20180904023036_drop_microposts.rb
class DropMicroposts < ActiveRecord::Migration[5.1]
  def up
    drop_table :microposts
  end
end

何かお気づきの箇所やご指摘など御座いましたらよろしくお願いします🙏🏽

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

+1

drop migrationファイルを作成し、一度rails db:migration:resetをしDBをリセット
drop migrationファイルを削除し、rails db:migrateを実施
この手順で成功しました!

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+1

マイグレーションファイルの実行順序はファイル名の順序(自動で生成されるタイムスタンプ)になると思いますので、dropより先にcreate tableが動くのではないかと思いますよ。

  • db/migrate/20180829203429_create_microposts.rb 
  • db/migrate/20180904023036_drop_microposts.rb 

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/09/04 13:05

    ご指摘ありがとうございます!
    ファイル順序に紐づくということですね💡
    `rails db:migrate:reset`にて一度リセットしてからdropファイルをmigrateしたところ削除できました!
    しかし、その後、micropostを作成し直そうと思うのですが、`rails db:migrate VERSION={*_create_microposts.rb}`を実施したところこれも怒られました。。。
    statusをみると全てupの状態になっていたのですが、これは再び実行したいファイルはdownにしてからversion指定にてmigrateすればいいのでしょうか?
    アドバイスよろしくお願いします🙏🏽

    キャンセル

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

  • Ruby

    8988questions

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

  • Ruby on Rails

    8397questions

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

  • Ruby on Rails 5

    2806questions

  • SQLite

    750questions

    SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。