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

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

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

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

MySQL

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

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

1回答

3348閲覧

ActiveRecord::StatementInvalid (Mysql2::Error: Table 'bookers2.users' doesn't exist: SHOW FULL FIELD

KEI_newdesign

総合スコア0

Ruby

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

MySQL

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

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2020/11/03 03:14

<質問背景>
Ruby on Railsで作成したアプリケーションをAWSでデプロイを試みています。EC2とRDS(データベース)を使っています。
ローカル環境はデータベースをSQliteで作成していて、なんの問題もありませんでした。しかし本番環境でMySQLを使用すると、下記エラーが発生しました。

イメージ説明

エラーの解消方法をご教示頂けると幸いです!!

<エラー内容>
下記が本番環境でのエラーログです。エラーを読むと「bookers2.users」が存在しないよ!と怒られています。

F, [2020-11-03T02:16:56.718447 #26388] FATAL -- : [38b0940e-09ec-47cd-8005-4d8b36e1a504] F, [2020-11-03T02:16:56.718482 #26388] FATAL -- : [38b0940e-09ec-47cd-8005-4d8b36e1a504] ActiveRecord::StatementInvalid (Mysql2::Error: Table 'bookers2.users' doesn't exist: SHOW FULL FIELDS FROM `users`): F, [2020-11-03T02:16:56.718505 #26388] FATAL -- : [38b0940e-09ec-47cd-8005-4d8b36e1a504] F, [2020-11-03T02:16:56.718544 #26388] FATAL -- : [38b0940e-09ec-47cd-8005-4d8b36e1a504] vendor/bundle/ruby/2.6.0/gems/mysql2-0.5.3/lib/mysql2/client.rb:131:in `_query'

<schemaの状態>

ActiveRecord::Schema.define(version: 2020_11_02_040523) do create_table "books", force: :cascade do |t| t.string "title", null: false t.text "body", null: false t.datetime "created_at", null: false t.datetime "updated_at", null: false t.integer "user_id" t.index ["user_id"], name: "index_books_on_user_id" end create_table "users", force: :cascade do |t| t.string "name", null: false t.string "introduction", null: false t.string "profile_image_id" t.string "encrypted_password", default: "", null: false t.string "reset_password_token" t.datetime "reset_password_sent_at" t.datetime "remember_created_at" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.string "email" t.index ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true end end

<mySQLのデータベース>

mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | bookers2 | | innodb | | mysql | | performance_schema | | samplenewdb | | sys | +--------------------+ 7 rows in set (0.00 sec)

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

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

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

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

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

winterboum

2020/11/03 04:05

database.ymlを載せてください アカウント情報はマスクして
KEI_newdesign

2020/11/03 04:20

winterboum様 早々に連絡頂きありがとうございます。下記コードがdatabase.ymlの内容です。 # SQLite version 3.x # gem install sqlite3 # # Ensure the SQLite 3 gem is defined in your Gemfile # gem 'sqlite3' # default: &default adapter: sqlite3 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> timeout: 5000 development: <<: *default database: db/development.sqlite3 # Warning: The database defined as "test" will be erased and # re-generated from your development database when you run "rake". # Do not set this db to the same as development or production. test: <<: *default database: db/test.sqlite3 production: <<: *default database: <%= ENV['DB_DATABASE'] %> adapter: mysql2 encoding: utf8mb4 charset: utf8mb4 collation: utf8mb4_general_ci host: <%= ENV['DB_HOST'] %> username: <%= ENV['DB_USERNAME'] %> password: <%= ENV['DB_PASSWORD'] %>
winterboum

2020/11/03 07:04

<%= ENV['DB_DATABASE'] %> は bookers2 で間違いないですね?
guest

回答1

0

エラーメッセージからみて、サーバーは起動しているようです。
ということは migrationを忘れたり、途中で失敗したりしているわけではなさそうです。
となると、table users をつくるmigrationが落ちている。。。。

git add しそこなったりしませんか?
git status してみてください

投稿2020/11/03 07:08

winterboum

総合スコア23416

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問