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

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

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

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

2回答

1467閲覧

[Ruby on Rails]Active Recordを使用したレコード検索

maonmyo

総合スコア36

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

2クリップ

投稿2016/10/21 02:40

編集2016/10/21 03:16

https://teratail.com/questions/37605

上記の質問と類似していますが、

Userテーブルに
user_id
first_name
last_name
があります。

フォームからID番号とフルネームを入力、検索、結果を表示させたいのですが、、

Ruby

1[controller] 2 3#ID番号のみ 4@user_list = User.where( user_id: params[:in_user_id] 5 6#名前のみの検索(sql文) 7select * from Users where concat(last_name, first_name) like ?", "%山田太郎%" 8

上の二つの構文を合わせて記述したいのですが、Active Recordを使用する場合の記述方法がわかりません。
(チェインも今ひとつ理解できていません。申し訳ありません。)

どなたか教えてください。

----------------追記----------------

申し訳ありません、
ID番号は前方一致検索にしたかったのでした。。

回答くださったのを参考に

Ruby

1 2@name = "山田太郎" 3 4@user_list = User.where(user_id: params[:in_user_id]).where(concat(last_name, first_name) like ?, %@name%) 5

このように書き直しましたが、
SyntaxErrorが出てしまいます。

上記のコードで言うと
like ?
が怒られてるみたいなのですが、、すみませんお願いします。

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

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

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

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

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

cameluby

2016/10/23 10:37

SQLは何を使っていますか?sqliteやMySQLなどの情報があると良いと思います。
maonmyo

2016/10/24 00:03

MySQLです。
guest

回答2

0

自己解決

回答やコメントなどありがとうございました!

いくつかのエラーが出ましたけど、なんとか自己解決いたしました!

Ruby

1 2@id = params[:user_id] #フォームから入力されたID番号 3@name = params[:hull_name] #フォームから入力されたフルネーム 4 5@user = User.where("id like ?", "#{@id}%").where("concat(last_name,first_name) like ?","%#{@name}%")

このようなコードで落ち着きました!

投稿2016/10/24 04:44

maonmyo

総合スコア36

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

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

0

フォームからID番号とフルネームを入力、検索、結果を表示させたい

ID番号はPrimay keyであるはずなので、これを指定するとレコードが一意に特定できますので、そこにさらにフルネームの検索条件を加えるというのは何かが間違えていると思いまじゅ。

それでも、やるのであれば

ruby

1@user_list = User.where(user_id: params[:in_user_id]).where(concat(last_name, first_name) like ?", "%山田太郎%")

でよろしいかと。

投稿2016/10/21 02:58

hana-da

総合スコア1728

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問