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

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

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

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

Q&A

解決済

1回答

821閲覧

where後に配列に入っている値のスマートな取り出し方

params_bird

総合スコア26

Ruby on Rails

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

0グッド

0クリップ

投稿2019/04/15 04:46

質問失礼いたします。

whereで値を取得した後は配列に入っていますが、

やはりwhereで値を取得した後はeachで取り出すしかないのでしょうか?

下記のコードですが、Entryモデル中の1つのroom_idには送信者、受信者のuser_idがあります。
(1つのroom_idにつき最小、最大2名のみです)
したがって自分以外のuser_idを残すためにwhere.notで自分のuser_idを取得しないようにしています。

@room_idには1つのuser_idしかないのがわかっている中で、
each文で取り出しはスマートではないなと感じております。

現在のコードです。

28: @room_id = Entry.where(room_id: params[:id]).where.not(user_id: current_user.id) 29: @room_id.each do |user| 30: @reception_user = User.find(user.user_id) => 31: binding.pry 32: end 33: link "#{@reception_user.name}さんとのチャットルーム", user_room_path

下記、@room_idに入っている値です。

> @room_id => [#<Entry:0x00007ff76be33a40 id: 2, user_id: 2, room_id: 1,

試したこと

配列からハッシュにするto_hメソッドを見つけて試しましたが、無理な様子です。

@room_id = Entry.where(room_id: params[:id]).where.not(user_id: current_user.id) @room = @room_id.to_h

エラー内容

wrong element type Entry (expected array)

質問

whereで値を取得し変数に入れた後、
同メソッド中でwhereの中に入っている配列の値をハッシュ形式で下記のように取り出す方法はないものでしょうか?

whereでも@hoge.nameのように値を取り出せたらいいなと思っております。

@user = User.find_by(last_name: "yamada") @user.first_name >>"taro"

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

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

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

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

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

guest

回答1

0

ベストアンサー

.firstを使ってはいかがでしょうか。

ruby

1@entry = Entry.where(room_id: params[:id]).where.not(user_id: current_user.id).first

投稿2019/04/15 04:59

maisumakun

総合スコア145183

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

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

params_bird

2019/04/15 05:20

勉強になります。 firstをこのように使うんですね。 スマートに解決できました。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問