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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

2377閲覧

ransackの範囲検索が上手くいきません。

nyan_tech_24

総合スコア17

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2020/05/10 08:50

前提・実現したいこと

検索機能を自分なりに試したく、ransackを使用しています。
現在numberカラムの範囲検索をでgteqとlteqを指定して検索したいです。
たとえば
1000 ~ 9999
と入力し、sql的には以下のように絞り込みたいです。

SELECT "searches".* FROM "searches" WHERE searches.number >= 1000 AND searches.number <= 9999;

発生している問題・エラーメッセージ

現在numberカラムのけgteqとlteqで以上以下の検索を行いたいのですが上手くいきません。
検索するとログに以下のSQL文が発行され、以上以下の値がとれません。

SELECT "searches".* FROM "searches" WHERE (CAST(searches.number AS CHAR(8)) >= '1000' AND CAST(searches.number AS CHAR(8)) <= '9999')

おそらく文字列で検索しているからだと思いますが、数字として検索をする場合はどうすればいいのかわかりません。
gemをインストール後にどこかのファイルで拡張する必要があるのでしょうか?
検索しているのですが、同じような症状が無かったため質問することにしました。

該当のソースコード

実装は以下になります。

index

1<%= search_form_for @q do |f| %> 2 <%= f.label :number_gteq %> 3 <%= f.number_field :number_gteq, class: "form-control" %> 4 <%= f.label :number_lteq, " ~ " %> 5 <%= f.number_field :number_lteq, class: "form-control" %> 6 <%= f.submit %> 7<% end %>

SearchesController

1class SearchesController < ApplicationController 2 3 def index 4 @q= Search.ransack(params[:q]) 5 @searches = @q.result 6 end 7end

schema

1create_table "searches", force: :cascade do |t| 2 t.integer "number" 3 t.datetime "created_at", precision: 6, null: false 4 t.datetime "updated_at", precision: 6, null: false 5 end

補足情報

DBはsqlite3を使用してます。

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

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

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

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

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

winterboum

2020/05/10 09:00

そのcodeで文字列扱いになるのが?? です 念の為、class Search も載せてください。
nyan_tech_24

2020/05/10 09:04

とくに何も指定してないのです。 ```Search class Search < ApplicationRecord end ``` なのでモデルかコントローラーに追加で記述、もしくは他のファイルを作成する必要があるでしょうか?
winterboum

2020/05/10 09:07

いや、私の経験ではこのままでうまく行きます。
guest

回答1

0

自己解決

自己解決

railsを再起動したら検索できるようになりました。

winterboumさん、お騒がせしました。
回答いただきありがとうございました。

投稿2020/05/10 09:08

nyan_tech_24

総合スコア17

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問