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

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

ただいまの
回答率

88.80%

Ransackで検索結果が表示されない

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 324

tokushun109

score 12

Ruby初心者で、初めて質問させていただきます。 質問内容に至らぬところがあるかもしれませんが、よろしくお願いいたします。

前提・実現したいこと

Ransackを用いて、userの検索機能を実装したい。

発生している問題

名前とユーザーネームの検索フォームから、
該当するユーザーを検索し一覧で表示したいと思っています。
現状では、データベースに存在するユーザーと、全く同じ名前とユーザーネームを打ち込んで検索をかけても、データベース中の全てのユーザーが表示されてしまいます。

該当のソースコード

routes.rb

resources :users, only: [:new, :create, :edit, :update] do
    collection do
      get :search
    end
  end

users_controller.rb

class UsersController < ApplicationController
・
・
・
  def search
    @search = User.ransack(params[:q])
    @users = @search.result
  end
・
・
・
end

search.html.erb

<div class="row">
    <div class="col-sm-6 offset-sm-3">
        <%= search_form_for @search, url: search_users_path do |f| %>
            <div class= "form-group">
                <%= f.label :user_name, 'ユーザーネーム' %>
                <%= f.text_field :user_name, class:'form-control' %>
            </div>
            <div class= "form-group">
                <%= f.label :name, '氏名' %>
                <%= f.text_field :name, class:'form-control' %>
            </div>
            <%= f.submit '検索', class: 'btn btn-primary btn-block mb-5' %>
        <% end %>
    <table class="table table-striped table-bordered">
        <tr>
            <th>ユーザーネーム</th>
            <th>氏名</th>
        </tr>
        <% @users.each do |user| %>
        <tr>
            <td><%= user.user_name %></td>
            <td><%= user.name %></td>
        </tr>
        <% end %>
    </table>
    </div>
</div>

試したこと

pry-byebugで

class UsersController < ApplicationController
・
・
・
  def search
    @search = User.ransack(params[:q])
    @users = @search.result
    binding.pry
  end
・
・
・
end


で検索フォームに該当するユーザーと同一の名前とユーザーネームを入れて検索しても、
@usersに全てのユーザーが入っていたため、検索で絞り込むこと自体ができていないと考えています。

お手数をおかけしますが、何卒ご教授のほどよろしくお願いいたします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

user_name というカラムと name というカラムの2つがあるという前提で説明してみます。
どちらかのカラムが存在しないようであれば、そっちはform-groupごと取っ払ってください。

現状

この部分を変更してみてください

<div class= "form-group">
    <%= f.label :user_name, 'ユーザーネーム' %>
    <%= f.text_field :user_name, class:'form-control' %>
</div>
<div class= "form-group">
    <%= f.label :name, '氏名' %>
    <%= f.text_field :name, class:'form-control' %>
</div>

変更後

各カラム名の後ろに _cont をつけるだけです

<div class= "form-group">
    <%= f.label :user_name_cont, 'ユーザーネーム' %>
    <%= f.text_field :user_name_cont, class:'form-control' %>
</div>
<div class= "form-group">
    <%= f.label :name_cont, '氏名' %>
    <%= f.text_field :name_cont, class:'form-control' %>
</div>

これで検索できるようになる気がします。

補足

英語への苦手意識があると辛いですが、ransackは公式の解説が充実しているので、他にも色々な検索方法を学ぶことができますよ。
activerecord-hackery/ransack

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/09/25 21:21

    回答ありがとうございます。
    ご教授いただいた内容を実施したところ無事解決いたしました。
    公式の解説も読んで、内容の理解に務めたいと思います。

    本当にありがとうございました。

    キャンセル

  • 2019/09/25 21:41

    よかったです!
    pry-byebugを使うほどの方であれば、ransack で複数テーブルが関わる検索などもすぐにできるようになると思います。
    頑張ってみてください。

    キャンセル

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

  • ただいまの回答率 88.80%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る