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

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

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

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

Q&A

解決済

1回答

914閲覧

rails 検索機能を実装したいのですが、検索後にエラーが出てしまいます

dragonnext

総合スコア3

Ruby on Rails 5

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

0グッド

0クリップ

投稿2020/08/20 06:29

railsで2つのモデルから検索機能を使って表示させようと思い、Userモデル、完全一致でMH(name)と検索すると下記エラーが出てしまいます。これは入力したMHが認識されていないということでしょうか。
どなたかアドバイス頂けると助かります。

ActiveRecord::StatementInvalid in Searches#search
Showing /home/vagrant/work/bookers-app_5/app/views/searches/search.html.erb where line #19 raised:

SQLite3::SQLException: no such column: MH: SELECT "users".* FROM "users" WHERE (MH)
Extracted source (around line #19):
17
18
19
20
21
22

<tbody> <% @user.each do |user| %> <tr> <td> <%= attachment_imege_tag(user, :profile_image, :fill, 50, 50, fallback: "no-image-mini.jpg") %>
フォームタグ <!--検索フォーム --> <% if user_signed_in? %> <%= form_tag(search_path, method: :get) do %> <%=text_field_tag 'word' %> <%= select_tag 'range', options_for_select([['---選択してください---',''], ['User', '1'], ['Book', '2']]) %> <%= select_tag 'search', options_for_select([['前方一致', 'forword_match'], ['後方一致', 'backword_match'],['完全一致', 'perfect_match'], ['部分一致', 'partial_match']]) %> <%= submit_tag '検索' %> <% end %> <% end %>    <!--検索フォーム -->
searches controller class SearchesController < ApplicationController def search @range = params[:range] search = params[:search] word = params[:word] if @range == '1' @user = User.search(params[:search],params[:word]) else @book = Book.search(search,word) end end end
user.rb def self.search(search,word) if search == "forword_match" User.where(["name LIKE?", "#{word}%"]) elsif search == "backword_match" User.where(["name LIKE?", "%#{word}"]) elsif search == "perfect_match" User.where(["#{word}"]) elsif search == "partial_match" User.where(["name LIKE?", "%#{word}%"]) else User.all end end
book.rb def self.search(search,word) if search == 'forword_match' @book = Book.where('title LIKE?', '#{word}%') elsif search == 'backword_match' @book = Book.where('title LIKE?', '%#{word}') elsif search == 'perfect_match' @book = Book.where('#{word}') elsif search == 'partial_match' @book = Book.where('title LIKE?','%#{word}%') else @book = Book.all end end
search.html.erb <% if @range == '1' %> <h2>Users search for #{word}</h2> <table class="table"> <thead> <tr> <th>image</th> <th>name</th> </tr> </thead> <tbody> <% @user.each do |user| %> <tr> <td> <%= attachment_imege_tag(user, :profile_image, :fill, 50, 50, fallback: "no-image-mini.jpg") %> </td> <td><%= user.name %></td> <td><%= link_to 'show', user_path(user) %></td> </tr> <% end %> </tbody> </table> <% else %> <h2>Books search for #{word}</h2> <table class="table"> <thead> <tr> <th>image</th> <th>name</th> </tr> </thead> <tbody> <% @book.each do |book| %> <tr> <td> <%= attachment_imege_tag(book.user, :profile_image, :fill, 50, 50, fallback: "no-image-mini.jpg") %> </td> <td><%= book.user.name %></td> <td><%= link_to 'show', user_path(book.user) %></td> </tr> <% end %> </tbody> </table> <% end %>

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

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

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

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

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

guest

回答1

0

ベストアンサー

User.where(["#{word}"]) でなく
User.where(name: word)

投稿2020/08/20 08:17

編集2020/08/20 08:17
winterboum

総合スコア23567

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

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

dragonnext

2020/08/20 08:30

ありがとうございます! 完全一致のときは#{}ではないんですね。 ちなみになのですが,search.html.erb の見出しに、入力した検索ワードを出したいのですがその際も#{word}ではないですか?いろいろ試したのですがwordが反映されず、、、、
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問