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

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

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

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

Ruby on Rails

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

Q&A

解決済

2回答

4007閲覧

【Ruby On Rails5】RansackでOR検索を実装したい

haruhi.

総合スコア18

Ruby on Rails 5

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

Ruby on Rails

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

0グッド

0クリップ

投稿2019/04/17 08:39

実現したいこと

RansackでOR検索を実装したい。

前提

お世話になります。
現在Ruby On RailsでRansackを使って、複数キーワードでひとつのテーブル(Item)を検索できる機能を作りたいと考えています。

http://nekorails.hatenablog.com/entry/2017/05/31/173925#023-any---OR%E3%81%A7%E7%B9%8B%E3%81%90%E5%80%A4%E3%81%8C%E8%A4%87%E6%95%B0

上記サイトを参考にname_eq_anyを用い、また複数キーワードを入力する際のスペースをカンマ区切りにするために、以下のように書きました。

view

1<%= search_form_for @q do |f| %> 2<%= f.search_field :name_cont_any,"キーワードを入力" %> 3<%end%>

controller

1@q = Product.ransack(params[:q]).split(",")

発生している問題

text_fieldに『ほげ ぴよ』と入力した場合、

SELECT `products`.* FROM `products` WHERE (`products`.`name` = 'ほげ' OR `products`.`name` = 'ぴよ')

となってほしいところのですが、上に述べました現状ではカンマが区切られず

SELECT `products`.* FROM `products` WHERE (`products`.`name` = 'ほげ ぴよ')

となってしまい、OR検索になりません。

どのように記載すれば想定通りのOR検索を作ることができますでしょうか。
どなたか解決策をご存知の方がいらっしゃいましたら、お知恵を貸していただけますと幸いです。

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

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

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

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

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

guest

回答2

0

ベストアンサー

unless params[:q][:name_cont_any].blank? keywords = params[:q][:name_cont_any].split(/\p{blank}/) keywords.delete('') end @q = Product.ransack(name_cont_any: keywords) @products = @q.result

フォームに入力した値がスペースなどで区切られている(例: 'a b')としたらこのような実装でしょうか
検索せずにアクセスした際はparams[:q][:name_cont_any]nilになってしまい、nilsplitすることを防ぐためにこのような書き方となっております。

投稿2019/05/04 12:18

haneru

総合スコア440

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

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

haruhi.

2019/05/09 05:40

お返事遅くなり大変申し訳ございません! つい先日無事自力で解決したのですが、いただいたコードとほぼ同じ形でした。 この度はご回答いただき本当にありがとうございました!
guest

0

コントローラーを次のように書いてみてください。

@q = Product.ransack(name_eq_any: params[:q][:name_cont_any].split(",")) @products = @q.result

投稿2019/04/17 10:15

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

haruhi.

2019/04/18 02:22

ご回答いただきありがとうございます! いただいたコードを試してみたところ、『undefined method `split' for nil:NilClass』と怒られてしまいました。 Controllerにspiltは使えないのでしょうか…
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問