一覧画面の検索フォームで、sity_name
とsity_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)%>
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/12/15 12:38