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

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

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

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

Ruby on Rails

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

解決済

ransackで日付指定検索ができない rails

ikutyan46
ikutyan46

総合スコア0

Ruby

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

Ruby on Rails

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

1回答

0評価

0クリップ

1577閲覧

投稿2020/06/17 08:35

編集2022/01/12 10:58

#実現したいこと
①gem ransackを使い、練習日(:training_date)の検索をかけたい
②かつ、ソート機能で練習日の並べ替えを行いたい

#環境
・Ruby:2.6.5
・Rails:5.2.4.3

#試したこと
①gem ransackをインストール
②Git Hubのdocumentに倣い、下記のようにControllerを設定

Controller

def index @records = current_user.records.includes(:practices).page(params[:page]).per(8) @q = Record.ransack(params[:q]) @search_records = @q.result(distinct: true) end

③index画面にて、下記のように記述

slim

h1 練習記録一覧 .container .form-group = search_form_for @q do |f| = f.date_field :training_date_cont = f.submit "検索"

④画像の通りに出力され、検索ボタンを押すが、反応なし

イメージ説明

⑤念のため、ログを確認すると、下記の通りとなっています。

おそらく、
・どのUserかを読み込み
・今ログインしているUserの中のrecordモデルから、recordテーブルを選択(?)
・順に、Record_idが、Xのpracticesモデルから、practicesテーブルを選択(?)して表示

と読んだのですが、そこから、どうすべきなのか考えが思い浮かばず、考え方や解決策をご教授頂ければ幸いです。
(なお、:contを、:eqに変更してもダメでした)

Started GET "/" for ::1 at 2020-06-17 17:18:33 +0900 Processing by RecordsController#index as HTML User Load (0.6ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT $2 [["id", 3], ["LIMIT", 1]] ↳ /Users/user/.rbenv/versions/2.6.5/lib/ruby/gems/2.6.0/gems/activerecord-5.2.4.3/lib/active_record/log_subscriber.rb:98 Rendering records/index.html.slim within layouts/application Rendered records/_flash_messages.html.slim (23.6ms) Record Load (0.5ms) SELECT "records".* FROM "records" WHERE "records"."user_id" = $1 LIMIT $2 OFFSET $3 [["user_id", "3"], ["LIMIT", 8], ["OFFSET", 0]] ↳ app/views/records/index.html.slim:27 Practice Load (1.2ms) SELECT "practices".* FROM "practices" WHERE "practices"."record_id" IN ($1, $2, $3, $4) [["record_id", 63], ["record_id", 64], ["record_id", 65], ["record_id", 68]] ↳ app/views/records/index.html.slim:27 (0.3ms) SELECT SUM("practices"."practice_time") FROM "practices" WHERE "practices"."record_id" = $1 [["record_id", 63]] ↳ app/views/records/index.html.slim:31 (0.3ms) SELECT SUM("practices"."practice_time") FROM "practices" WHERE "practices"."record_id" = $1 [["record_id", 64]] ↳ app/views/records/index.html.slim:31 (0.3ms) SELECT SUM("practices"."practice_time") FROM "practices" WHERE "practices"."record_id" = $1 [["record_id", 65]] ↳ app/views/records/index.html.slim:31 (0.2ms) SELECT SUM("practices"."practice_time") FROM "practices" WHERE "practices"."record_id" = $1 [["record_id", 68]] ↳ app/views/records/index.html.slim:31 Rendered records/index.html.slim within layouts/application (44.6ms) Rendered records/_header.html.slim (3.7ms) Completed 200 OK in 72ms (Views: 63.7ms | ActiveRecord: 3.5ms)

#コード(全部)

Controller

class RecordsController < ApplicationController before_action :authenticate_user! def index @records = current_user.records.includes(:practices).page(params[:page]).per(8) @q = Record.ransack(params[:q]) @search_records = @q.result(distinct: true) end def show @record = Record.find(params[:id]) end def new @record = Record.new output = @record.outputs.build practice = @record.practices.build task = @record.tasks.build end def create @record = Record.new(record_params) logger.info "###### #{@record.inspect}" if @record.save flash[:success] = "練習内容の登録が完了しました。" redirect_to records_url else flash[:alert] = "登録に失敗しました。" render :new end end def edit @record = Record.find_by(id: params[:id]) end def update @record = Record.find_by(id: params[:id]) if @record.update(record_params) flash[:success] = "練習内容の更新が完了しました。" redirect_to records_url else flash[:alert] = "更新に失敗しました。" render :edit end end def destroy record = Record.find_by(id:params[:id]) record.destroy redirect_to root_path, notice: "練習記録を削除しました。" end def aggregate_result @record = Record.find(params[:id]) gon.data = Record.where(params[:practice_time]) 6.times do # gon.data << rand(100.0) end end private def set_user @user = current_user || User.new end def record_params params.require(:record).permit(:record_id, :training_date, :learning_point, outputs_attributes:[:output_name, :id, :_destroy], practices_attributes:[:practice_item, :practice_time, :id, :_destroy], tasks_attributes:[:task_name, :id, :_destroy]).merge(user_id: current_user.id) end end

index

= render 'records/flash_messages' h1 練習記録一覧 .container .form-group = search_form_for @q do |f| = f.date_field :training_date_cont = f.submit "検索" .d-flex .col-4.text-align: center = link_to '新規登録', new_record_path, class: 'btn btn-primary' .col-4.text-align: center = link_to 'リマインダー設定', new_record_path, class: 'btn btn-primary' .col-4.text-align: center = link_to 'レポートを見る', aggregate_result_record_path(current_user.id), class: 'btn btn-primary' table.table-hover.table-respnsive thead tr th= sort_link(@q, :training_date, '練習日') th= sort_link(@q, :created_at, '登録日時') th 総練習時間 th th tbody - @records.each do |record| tr td= link_to record.training_date, record_path(record) td= record.created_at td= record.practices.sum(:practice_time) / td= total td = link_to '編集する', edit_record_path(record), class: 'btn btn-primary mr-3' = link_to '削除する', record_path(record), method: :delete, data: { confirm: "練習記録を削除します。よろしいですか?" }, class: 'btn btn-danger' = paginate @records

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

Ruby

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

Ruby on Rails

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。