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

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

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

Haml(HTML abstraction markup language)は、HTML/XHTMLを効率的に記述するためのマークアップ言語および記法です。

Ruby

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

Ruby on Rails

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

Q&A

解決済

1回答

1448閲覧

【Rails】エラーを解決し、検索結果を表示できるようにしたい

hatori_r

総合スコア10

Haml

Haml(HTML abstraction markup language)は、HTML/XHTMLを効率的に記述するためのマークアップ言語および記法です。

Ruby

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

Ruby on Rails

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

0グッド

2クリップ

投稿2020/06/16 04:59

ActiveRecord::StatementInvalid in Tasks::Searches#indexを解決し検索結果を表示できるようにしたい

 RailsでToDoアプリのようなものを作っています。
現在タスク一覧画面に検索フォームを設置し、検索ができるような機能を実装中です。
そこでユーザーが文字を入力し検索したものを表示させる記述を行ったのですが以下のエラーが発生してしましました。

発生している問題・エラーメッセージ

エラー詳細

ActiveRecord::StatementInvalid in Tasks::Searches#index Mysql2::Error: Unknown column 'text' in 'where clause': SELECT `tasks`.* FROM `tasks` WHERE (text LIKE('%%'))

該当のソースコード

  • app/models/task.rb

model

1class Task < ApplicationRecord 2 belongs_to :user 3 has_many :comments 4 5 def self.search(search) 6 if search 7 Task.where('text LIKE(?)', "%#{search}%") 8 else 9 Task.all 10 end 11 end 12end
  • app/views/tasks/searches/index.html.haml

view

1= form_with(url: tasks_searches_path, local: true, method: :get, class: "search-form") do |f| 2 = f.text_field :keyword, placeholder: "Search for tasks", class: "search-input" 3 = f.submit "Search", class: "search-btn" 4.contents.row 5 - @tasks.each do |t| 6 = render partial: "tasks/task", locals: { t: t }
  • app/controllers/tasks/searches_controller.rb

controller

1class Tasks::SearchesController < ApplicationController 2 def index 3 @tasks = Task.search(params[:keyword]) 4 end 5end

試したこと

恐らくミス記入が原因と思いましたが、特に記述ミスと思われるところはありませんでした。

こちらの原因がおわかりの方がいましたら、どうか教えていただけらたと思います。
よろしくお願い致します。

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

viewの- @tasks.each のところでTask.search(params[:keyword])で定義されたdef self.search(search)によるTask.where('text LIKE(?)', "%#{search}%")が実行されます。
ので、エラー発生源がviewになってます。
このwherの中の'text LIKE(?)', "%#{search}%")この textがTaskのDB table tasks に無いというエラーです。
schemaを見なおしてください

投稿2020/06/16 09:57

winterboum

総合スコア23329

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

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

hatori_r

2020/06/16 11:43

回答をいただきありがとうございます 参考にさせていただきます。
hatori_r

2020/06/16 11:56

```schema create_table "tasks", options: "ENGINE=InnoDB DEFAULT CHARSET=utf8", force: :cascade do |t| t.text "state" t.text "task" t.text "image" t.date "limit_date" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.integer "user_id" end ``` ご指定機をいただいたとおりschema.rbを確認しました。 今一度確認をしてみたのですが、taskの型はtextとなっておりました。 恐縮ですが、学習を始めたばかりのものでよくわかっていないので、一度この部分を調べてみます。 もし分からなければ、再度質問を投稿をさせていただきたいと思います。 ありがとうございました。
winterboum

2020/06/16 12:30

型でなくcolumn名を入れてください。 task LIKE(?)', "%#{search}%") かな
hatori_r

2020/06/16 13:37

いつも親切にありがとうございます。 大変参考になり助かっております。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問