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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

1202閲覧

検索が上手くいかない

nnnn5

総合スコア18

Ruby

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

Ruby on Rails

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

0グッド

1クリップ

投稿2019/03/14 08:08

編集2019/03/15 05:03

前提・実現したいこと

検索でワードが引っかかるようにしたいです。

railsでブログを作成しています。
タグの名前や、地域の場所の名前を検索ワードとして引っかからせたいんですが、後半に書く方しか検索に引っかかりません。(今回の場合tag)

※articleテーブルは
article(記事テーブル)-article_tags(中間テーブル)-tag(タグテーブル)
article(記事テーブル)-article_tags(中間テーブル)-pref(地域テーブル)
の多対多を二つ持っています。

該当のソースコード

article.rb def self.search(search_word) if search_word Article.joins(:prefs).merge(Pref.where('name LIKE(?)', "%#{search_word}%")) Article.joins(:tags).merge(Tag.where('name LIKE(?)', "%#{search_word}%")) else Article.all end
tops_controller.rb @articles = Article.search(params[:search])
index.html.erb <% @articles.each do |article| %> <div class = "article-box"> <div class = "image"> <%= link_to image_tag("#{article.image_url}",:class=>"image"), top_path(:id => article.id) %> </div> <h3 class="title"><%= link_to article.title , top_path(:id => article.id)%></h3> <p class = "tag"><%= link_to article.tags.first.name, "#" %></p> <time class="date"><%= article.created_at.strftime("%Y-%m-%d") %></time> </div> <% end %>

試したこと

joinについてやincludeについなども調べたんですがどうやって書くと上手くいくのか解決策が見つかりませんでした、、
回答お願いします( i _ i )

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

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

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

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

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

gouf

2019/03/14 10:17

当該部分を「Article.joins(:prefs, :tags).merge(Pref.where('name LIKE(?)', "%#{search_word}%")).merge(Tag.where('name LIKE(?)', "%#{search_word}%"))」と書き換えた場合、なにか変化は見られますか?
FKM

2019/03/14 10:19

対象箇所のフォームについて、htmlかhtml.slimかhamlといったビューのソースはありませんでしょうか?
nnnn5

2019/03/14 10:51

ActiveRecord::StatementInvalid in Tops#index Mysql2::Error: Column 'name' in where clause is ambiguous: SELECT `articles`.* FROM `articles` INNER JOIN `article_prefs` ON `article_prefs`.`article_id` = `articles`.`id` INNER JOIN `prefs` ON `prefs`.`id` = `article_prefs`.`pref_id` INNER JOIN `article_tags` ON `article_tags`.`article_id` = `articles`.`id` INNER JOIN `tags` ON `tags`.`id` = `article_tags`.`tag_id` WHERE (name LIKE('%新潟%')) AND (name LIKE('%新潟%')) AND `articles`.`status` = TRUE ORDER BY `articles`.`created_at` DESC LIMIT 6 OFFSET 0 このエラーになりました。。
gouf

2019/03/14 10:59 編集

「where clause is ambiguous」になるのを失念していました。merge しようとしている部分の「name」をテーブル名も含めた...「tags.name」のように...明示した場合だと エラーなく実行されますか?
nnnn5

2019/03/14 11:06

すみません、、、書き方がわからず ``` Article.joins(:prefs, :tags).merge(Pref.where(prefs: 'name LIKE(?)', "%#{search_word}%")).merge(Tag.where(tags: 'name LIKE(?)', "%#{search_word}%")) ``` でsyntaxerrorになってしまいます、、、
gouf

2019/03/14 11:08

Article.joins(:prefs, :tags).merge(Pref.where('prefs.name LIKE(?)', "%#{search_word}%")).merge(Tag.where('tags.name LIKE(?)', "%#{search_word}%")) のような書き方です。このコード片は動作しますか?
nnnn5

2019/03/14 11:12

ありがとうございます( i _ i )エラーは出ていないんですが、ちゃんとサーチされていないみたいです、、 sqlです Article Load (12.7ms) SELECT `articles`.* FROM `articles` INNER JOIN `article_prefs` ON `article_prefs`.`article_id` = `articles`.`id` INNER JOIN `prefs` ON `prefs`.`id` = `article_prefs`.`pref_id` INNER JOIN `article_tags` ON `article_tags`.`article_id` = `articles`.`id` INNER JOIN `tags` ON `tags`.`id` = `article_tags`.`tag_id` WHERE (prefs.name LIKE('%新潟%')) AND (tags.name LIKE('%新潟%')) AND `articles`.`status` = TRUE ORDER BY `articles`.`created_at` DESC LIMIT 6 OFFSET 0 ↳ app/views/tops/_article_list.html.erb:1
guest

回答1

0

ベストアンサー

def self.search(search_word) if search_word self.joins(:prefs, :tags) .where(Pref.arel_table[:name].matches("%#{search_word}%") .or(Tag.arel_table[:name].matches("%#{search_word}%")) else self.all end end

このような書き方でいかがでしょうか
メソッドの返り値は最後に出力された内容のため、npmisakiさんの書き方ですと後者のみしか結果が返ってきません。

投稿2019/05/04 12:44

haneru

総合スコア440

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問