前提・実現したいこと
検索でワードが引っかかるようにしたいです。
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 )
当該部分を「Article.joins(:prefs, :tags).merge(Pref.where('name LIKE(?)', "%#{search_word}%")).merge(Tag.where('name LIKE(?)', "%#{search_word}%"))」と書き換えた場合、なにか変化は見られますか?
対象箇所のフォームについて、htmlかhtml.slimかhamlといったビューのソースはありませんでしょうか?
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
このエラーになりました。。
「where clause is ambiguous」になるのを失念していました。merge しようとしている部分の「name」をテーブル名も含めた...「tags.name」のように...明示した場合だと エラーなく実行されますか?
すみません、、、書き方がわからず
```
Article.joins(:prefs, :tags).merge(Pref.where(prefs: 'name LIKE(?)', "%#{search_word}%")).merge(Tag.where(tags: 'name LIKE(?)', "%#{search_word}%"))
```
でsyntaxerrorになってしまいます、、、
Article.joins(:prefs, :tags).merge(Pref.where('prefs.name LIKE(?)', "%#{search_word}%")).merge(Tag.where('tags.name LIKE(?)', "%#{search_word}%")) のような書き方です。このコード片は動作しますか?
ありがとうございます( 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
回答1件
あなたの回答
tips
プレビュー