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

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

ただいまの
回答率

90.49%

  • Ruby on Rails

    7475questions

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

マイグレーションでundefined method `to_sym' for nil:NilClassと返ってきます。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,584

TakumaN

score 110

前提・実現したいこと

bundle exec rake db:migrateでのエラーを改善したいです。

発生している問題・エラーメッセージ

$ bundle exec rake db:migrate
== 20160325085507 ChangeUserIdToGalleries: migrating ==========================
-- change_column(:galleries, :user_id, :integer)
rake aborted!
StandardError: An error has occurred, this and all later migrations canceled:

undefined method `to_sym' for nil:NilClass
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/abstract/schema_definitions.rb:258:in `column'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:546:in `block (2 levels) in copy_table'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:539:in `each'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:539:in `block in copy_table'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/abstract/schema_statements.rb:216:in `create_table'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:536:in `copy_table'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:529:in `move_table'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:522:in `block in alter_table'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/abstract/database_statements.rb:211:in `transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:521:in `alter_table'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/sqlite3_adapter.rb:485:in `change_column'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:665:in `block in method_missing'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:634:in `block in say_with_time'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:634:in `say_with_time'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:654:in `method_missing'
/Users/takuman/earth/db/migrate/20160325085507_change_user_id_to_galleries.rb:3:in `change'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:608:in `exec_migration'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:592:in `block (2 levels) in migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:591:in `block in migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/abstract/connection_pool.rb:292:in `with_connection'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:590:in `migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:768:in `migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:998:in `block in execute_migration_in_transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:1044:in `block in ddl_transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/abstract/database_statements.rb:213:in `block in transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/abstract/transaction.rb:184:in `within_new_transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/connection_adapters/abstract/database_statements.rb:213:in `transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/transactions.rb:220:in `transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:1044:in `ddl_transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:997:in `execute_migration_in_transaction'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:959:in `block in migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:955:in `each'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:955:in `migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:823:in `up'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/migration.rb:801:in `migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/tasks/database_tasks.rb:137:in `migrate'
/Library/Ruby/Gems/2.0.0/gems/activerecord-4.2.6/lib/active_record/railties/databases.rake:44:in `block (2 levels) in <top (required)>'
Tasks: TOP => db:migrate
(See full trace by running task with --trace)

migrate/20160325085507_change_user_id_to_galleries.rb

class ChangeUserIdToGalleries < ActiveRecord::Migration
  def change 
      change_column :galleries, :user_id, :integer
  end
end

補足情報(言語/FW/ツール等のバージョンなど)

Ruby 2.0.0
rails 4.2.6
rake 11.1.1

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • raccy

    2016/03/26 09:30

    migrate/20160325085507_change_user_id_to_galleries.rb があやしいですので、それも一緒に貼り付けていただけませんか?

    キャンセル

  • TakumaN

    2016/03/26 10:13

    追加しました!

    キャンセル

回答 1

checkベストアンサー

0

考えられる原因として、galleriesテーブルにuser_idカラムがないと推測されます。change_columnは既存のカラムの変更になりますが、user_idはすでに作成されている状態でしょうか?galleriesテーブルに関する各migrationを確認し、user_idが作られるかどうか確認してみて下さい。また、migrateする既存DBでuser_idがあるかも確認してみて下さい。developmentのDBであれば、rake db:reset`rake db:migrate:resetでDBをはじめから作り直した場合どうなるかを確認してみて下さい。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/03/26 11:29

    user_idはすでに作成されており、マイグレーションファイルもあります。
    sqlite3のデータベースから確認してみてもgalleriesテーブル内にuser_idがちゃんとありました。

    rake db:resetを実行するとgalleriesテーブルだけがデータベースから消えました。(他のテーブルはちゃんと残っています。)

    そのあとにrake db:migrate:resetを実行すると、またgalleriesテーブルが出てきました。

    そのあとに再びrake db:migrateでマイグレーションを実行してみても同じエラーが表示されました。

    キャンセル

  • 2016/03/26 17:29

    db/schema.rbとmigrateの間で不整合を起こしているのかも知れません。下記を参考にしてみてください。
    http://easyramble.com/difference-bettween-rake-db-migrate-reset.html
    db/schema.rbについては下記も参考になるかと思います。
    http://qiita.com/k0kubun/items/491a9d9f2745335566e3
    db/schema.rbを整合性が合うように編集するかなりすれば動くようになる可能性があります。

    キャンセル

  • 2016/03/26 20:19

    新たにマイグレーションファイルを生成して、rake db:migrateするのではなく、
    直接、変更したいカラムのマイグレーションファイルを書き直してから、rake db:migrate:resetするというやり方にしたところ、ちゃんとデータベースに反映されました!

    ご丁寧なアドバイスを何度もしてくださって、どうもありがとうございました!

    キャンセル

関連した質問

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

  • Ruby on Rails

    7475questions

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