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

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

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

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

Q&A

解決済

2回答

7137閲覧

ActiveRecordにて取得した配列から値を検索する方法について

naoki855

総合スコア75

Ruby on Rails

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

0グッド

1クリップ

投稿2016/11/13 07:46

編集2016/11/13 07:47

Ruby on Railsで、DBから取得したデータの取り扱いに関して質問があります。
もっとうまい書き方があると思い、質問させていただきました。

行いたいこととしては、下記になります。

  • いくつかの商品に関して、とあるユーザーが購入したかどうかを確認
  • その結果を商品ごとに、「購入したことがある」「購入したことがない」として返却する

Ruby on Railsのバージョンは5.0.0.1になります。


商品の購入履歴を管理しているsalesテーブルがあるとします。

id user_id 購入したユーザーのID item_id 商品のID count 購入した個数

ここで、下記のような、特定のユーザーで、かついくつかの商品IDに絞って検索をかけます。

rb

1@sales = Sale.where(user_id: 1).where(item_id: [1, 2, 3, 4])

この後、商品ごとに、その他のデータも整理しながら、レポートを作成します。
このとき、あるアイテムに対して、先ほど指定したユーザーがそのアイテムを購入したかどうかをbooleanで返したいと思っています。

rb

1items = Item.all 2 3items.each do |item| 4 # 省略 5 6 # ユーザーがそのアイテムを購入したかどうかを返す 7 if (@sales.to_a.find { |n| n[:item_id] == item.id }) == nil 8 user_bought_item = false 9 else 10 user_bought_item = true 11 end 12 13 # 省略 14end

上記の「 ユーザーがそのアイテムを購入したかどうかを返す 」部分のうまい書き方が分からず悩んでおります。
(アソシエーションは設定しない方向で考えております。)
こちら、もしお勧めの書き方などありましたらご教授ください。
宜しくお願い致します。

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

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

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

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

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

guest

回答2

0

自己解決

pluckを使用した方が良さそうだったため、下記のように再修正しました。

rb

1@sales = Sale.where(user_id: 1).where(item_id: [1, 2, 3, 4]).pluck(:item_id)

投稿2016/11/19 06:21

naoki855

総合スコア75

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

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

0

上記方法だと、N+1問題が発生するため、現状下記のようにしております。

rb

1@sales = Sale.where(user_id: 1).where(item_id: [1, 2, 3, 4]).map{ |sale| sale.item_id }

rb

1items = Item.all 2 3items.each do |item| 4 # 省略 5 6 # ユーザーがそのアイテムを購入したかどうかを返す 7 if @sales.include?(item.id) 8 user_bought_item = true 9 else 10 user_bought_item = false 11 end 12 13 # 省略 14end

やはり、配列にして、include?を使用するのが良いのでしょうか。。。

投稿2016/11/13 09:00

編集2016/11/13 09:01
naoki855

総合スコア75

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問