🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby on Rails 5

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

Ruby

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

MySQL

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

AWS(Amazon Web Services)

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

Q&A

解決済

1回答

1123閲覧

ローカル環境では動くのに、AWSにデプロイすると Mysql2::Error: Unknown column のerrorが出ます。

jsaku

総合スコア15

Ruby on Rails 5

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

Ruby

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

MySQL

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

AWS(Amazon Web Services)

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

0グッド

0クリップ

投稿2019/01/09 04:11

前提・実現したいこと

Userのshowページを表示したいです。

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

ローカルの環境では、問題なく表示できるのですが
AWSにデプロイして、該当ページを表示すると下記のエラーが表示されます。

We're sorry, but something went wrong.

そこでproduction.logを見てみると下記のエラーが表示されます。

ActionView::Template::Error (Mysql2::Error: Unknown column 'posts.user_id' in 'where clause': SELECT `posts`.* FROM `posts` WHERE `posts`.`user_id` = 1):

試したこと

ググってみると、モデルのアソシエーションがうまく出来ていないという記事が見られたので、モデルを確認しましたが解決には至りませんでした。

アソシエーションの表記に何か誤りがある気はするのですが、分からない状況です。

●テーブルの情報

create_table "users", force: :cascade do |t| t.string "email", default: "", null: false t.string "encrypted_password", default: "", null: false t.string "reset_password_token" t.datetime "reset_password_sent_at" t.datetime "remember_created_at" t.integer "sign_in_count", default: 0, null: false t.datetime "current_sign_in_at" t.datetime "last_sign_in_at" t.string "current_sign_in_ip" t.string "last_sign_in_ip" t.string "name" t.text "image_id" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.index ["email"], name: "index_users_on_email", unique: true t.index ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true end
create_table "posts", force: :cascade do |t| t.string "post_image_id" t.text "post_content" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.integer "user_id" end

●モデルの情報

class User < ApplicationRecord has_many :posts, dependent: :destroy end
class Post < ApplicationRecord belongs_to :user end

以上です。
何かお気付きの点ございましたら、ご教示頂けると幸いです。。

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

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

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

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

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

guest

回答1

0

ベストアンサー

User.find(1).posts的なことをしてSELECT `posts`.* FROM `posts` WHERE `posts`.`user_id` = 1が発行されていると思うのでアソシエーションは問題ないんじゃないかと思います
mysqlのコンソール等からpostsテーブルにuser_idカラムがあることが確認できますか?

投稿2019/01/09 05:35

uzr

総合スコア65

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

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

jsaku

2019/01/10 06:27

uzr様 ご回答ありがとうございます。 mysqlのコンソールから確認したところ、user_idカラムがありませんでした。 (ローカル環境でのschemaでは表示されるのに、データベースでは作成されない可能性があるケースを初めて知りました。) そこで、mysqlから直接user_id カラムを追加したところ、無事userのshowページが表示されました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問