teratail header banner
teratail header banner
質問するログイン新規登録

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

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

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

Cloud9は、クラウドからのプログラミングが可能になるWebサービス。IDEとしての機能が搭載されており、GitHubやHerokuなど他ツールとの連携も可能です。ブラウザ上で動くため、デバイスに関係なく開発環境を準備できます。

Ruby on Rails 5

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

Ruby

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

Q&A

解決済

1回答

2159閲覧

[rails]ransackの数値取得について

ukpapyrus

総合スコア19

Cloud9

Cloud9は、クラウドからのプログラミングが可能になるWebサービス。IDEとしての機能が搭載されており、GitHubやHerokuなど他ツールとの連携も可能です。ブラウザ上で動くため、デバイスに関係なく開発環境を準備できます。

Ruby on Rails 5

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

Ruby

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

0グッド

1クリップ

投稿2019/07/25 06:17

0

1

前提・実現したいこと

railsにてransackを用いて検索機能を実装中です。
文字の検索に関しては問題ないのですが、数値の検索がうまくいきません。
例えば100以上~200以下で検索すると、100,150,200など正常に範囲内の値を取得してくれるのですが、
50以上200以下で検索すると、値が一つも取得されないなど、検索結果が安定しません。
ransackの挙動に関して教えていただきたいです。

該当のソースコード

<%= f.label :capacity,"座席数",class:"label" %> <%= f.number_field :capacity_gteq, class:"form-control" %> <%= f.number_field :capacity_lteq, class:"form-control" %>

試したこと

最初は入力データがまずいのかなと考えたのですが、正常に取得してくれる場合もあるため、そういうわけではなさそうです。
色々調べたのですが、ransackの数値取得に関する質問は見当たらなかったため、質問させていただきました。
データの値としては、200,200,80,100,150,150,50(全角)があります。

補足情報(FW/ツールのバージョンなど)

ruby 2.5.0, rails 5.1.6, cloud9

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

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

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

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

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

guest

回答1

0

ベストアンサー

> データの値としては、200,200,80,100,150,150,50(全角)があります。

全角 ですか?
数字だけの項目だが文字データとして扱っている
のではないですか?
ですから 50以上200以下ですと 先頭の文字が5以上2以下でひとつもhitしない。

という推測があたっているかどうか。
table定義を確認して下さい

投稿2019/07/25 07:29

winterboum

総合スコア23653

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

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

ukpapyrus

2019/07/25 08:31

おっしゃる通り、検索フォームは数字型ですがデータの型は文字型にしていました。 データ型をintegerに変更することで、解決できました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問