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

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

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

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

Q&A

解決済

1回答

301閲覧

一覧画面でjoinsとmergeを使って別テーブルから検索できるようにしたい

kokosi1062

総合スコア39

Ruby on Rails 6

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

0グッド

0クリップ

投稿2021/12/14 11:02

一覧画面の検索フォームで、sity_namesity_codeを検索して一覧画面に表示させたい内容です。
現状、sity_codeフォームの方は検索して問題なく一覧画面に表示できています。
sity_nameの方は、usa_userテーブルに定義していないので、usaテーブルから
引っ張り出して検索したいです。
そのためindexアクションに下記を追記したのですが、エラーが出ました。
** @usa_users = UsaUser.joins(usa: :sity_name).merge(Usa.where('sity_name LIKE ?', "%#{params[:sity_name]}%"))**
joinsとmergeの書き方が間違っていますでしょうか。
ご教授いただけますと幸いです。

エラー文 ActiveRecord::ConfigurationError in UsaUsers#index Can't join 'Usa' to association named 'sity_name'; perhaps you misspelled it? Extracted source (around line #52): <% @usa_users.each do |usa_user| %>
usa_users_controller.rb class UsaUsersController < ApplicationController def index @usa_users = UsaUser.page(params[:page]).per(25) @usa_users = UsaUser.joins(usa: :sity_name).merge(Usa.where('sity_name LIKE ?', "%#{params[:sity_name]}%")) @usa_users = @usa_users.where('sity_code LIKE ?', "%#{params[:sity_code]}%") end
models/usa.rb class Usa < ApplicationRecord has_many :usa_users, primary_key: %i[sity_code],foreign_key: %i[sity_code] end
models/usa_user.rb class UsaUser < ApplicationRecord belongs_to :usa, primary_key: %i[sity_code], foreign_key: %i[sity_code]
usa_users/index.html.erb <%= form_with url: usa_users_path, method: :get, local: true do |form| %> <%= form.label :sity_code, "都市データ" %> <%= form.text_field :sity_code %> <br> <%= form.label :sity_name, "都市名" %> <%= form.text_field :sity_name %> <br> <%= form.submit '検索', name: nil %> <% end %> <% @usa_users.each do |usa_user| %> <tr> <td><%= usa_user.sity_code %></td> <td><%= usa_user.usa.sity_name %></td> </tr> <% end %> <%= paginate(@usa_users)%>

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

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

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

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

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

guest

回答1

0

ベストアンサー

UsaUser.joins(usa: :sity_name) この意味は、UsaUser に Usaをjoinしさらに「Usa がhas_one もしくは belongs_to している SityNameもjoinする」という意味です。
sity_name が Usaのcolumnならと joins(:usa) です。
なお、primary_key: %i[sity_code] これはおかしいです。
この意味は primary_key: [:sity_code] ですprimary_key: :sity_code であるはず。

投稿2021/12/15 04:39

winterboum

総合スコア23416

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

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

kokosi1062

2021/12/15 12:38

解説いただきありがとうございます。 こちらの意味を間違って認識していました。 UsaUser.joins(usa: :sity_name) 下記に修正したらいけました。 @usa_users = UsaUser.joins(:usa).merge(Usa.where('usas.sity_name LIKE ?', "%#{params[:sity_name]}%"))
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問