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

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

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

Deviseとは、Ruby-on-Railsの認証機能を追加するプラグインです。

MySQL

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

Ruby on Rails

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

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

Q&A

解決済

1回答

649閲覧

アソシエーションを組んでないモデルのビューに表示させるには‥

hayatoganbaru

総合スコア7

Devise

Deviseとは、Ruby-on-Railsの認証機能を追加するプラグインです。

MySQL

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

Ruby on Rails

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

データベース設計

データベース設計はデータベースの論理的や物理的な部分を特定する工程です。

0グッド

0クリップ

投稿2021/07/25 09:52

実装中のアプリケーション

現在、ライブハウスの経営者向けの
アプリケーションを実装中です。
ウィザード形式でプロフィール欄(admin_profilesテーブル)を記入後、
新規登録をしたライブハウス経営者(admin_usersテーブル)は
イベントの投稿(eventsテーブル)をすることができます。

困っていること

アソシエーション
admin_usersテーブルとadmin_profilesテーブルは
1対1の関係です。
admin_usersテーブルはhas_one
admin_profilesテーブルはbelongs_to

admin_usersテーブルとeventsテーブルは1対多の関係です。
admin_usersテーブルはhas_many
eventsテーブルはbelongs_to

イベント一覧表示ページにadmin_profilesテーブルの
prefecture_idを表示させたいのですが、
eventsテーブルとadmin_profilesテーブルはアソシエーションを
組んでいません。
どのように実装すればprefecture_idを表示させることが
できるのでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

event.admin_user.admin_profile.prefecture_id
で表示できるかと思います。
databaseへのアクセスを減らすには、ひと工夫必要ですが。
@events = Event.includes(admin_users: :admin_profile).where....
で行けるかな

投稿2021/07/25 11:30

winterboum

総合スコア23567

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

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

hayatoganbaru

2021/07/26 21:00

ご回答ありがとうございます。 返信が遅くなり、大変申し訳ありません。 eventsコントローラーのindexアクションにおいて @events = Event.includes(admin_users: :admin_profile).where.(id: ids).order('created_at DESC')と記述しました。 するとNameErrorとなりidsのところがダメと言われました。 特に記述は間違っていないように僕は感じましたが、 何が原因でしょうか?
winterboum

2021/07/26 22:43

ids をどこで定義してます?
hayatoganbaru

2021/07/27 01:57

イベントの投稿を一覧表示させるためにevents_controllerのindexアクションで定義しました。 def index @events = Event.includes(admin_users: :admin_profile).where.(id: ids).order('created_at DESC') end
winterboum

2021/07/27 03:57

いや、それは「使っている」「参照している」であって、定義、代入 していません
hayatoganbaru

2021/07/28 01:54

意味を履き違えており、申し訳ありません。 お教えいただき、ありがとうございます。 idsが定義されてないからNameErrorが起こったということでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問