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

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

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

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

Ruby

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

Ruby on Rails

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

Q&A

解決済

2回答

2287閲覧

Rails: Excelのvlookup関数のように、他テーブルのカラムからデータを引っ張ってくる方法

masaki5.5

総合スコア10

Ruby on Rails 5

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

Ruby

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

Ruby on Rails

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

0グッド

1クリップ

投稿2019/08/01 14:34

編集2019/08/03 02:12

Rails 初心者です。

Excelのvlookup関数のように、他テーブルのカラムからデータを引っ張ってくる方法を探しています。
具体的には、以下のようなことをするのが目的です。

1). モデル(テーブル)が以下のように4つあります。

ruby

1class User < ApplicationRecord 2 has_many :user_shop_items 3 has_many :user_shop_item_categories 4 has_many :shop_items, through: :user_shop_items 5 has_many :shop_item_categories, through: :user_shop_item_categories 6end 7 8class ShopItem < ApplicationRecord 9 has_many :user_shop_items 10 has_many :users, through: :user_shop_items 11end 12 13class UserShopItem < ApplicationRecord 14 belongs_to :user 15 belongs_to :shop_item 16end 17 18class UserShopItemCategory < ApplicationRecord 19 belongs_to :user 20 belongs_to :shop_item_category 21end

User

idname
1A
2B
3C

ShopItem

idnameshop_item_category_id
1A'1
2B'2
3C'2
4D'3

UserShopItem
|id|user_id|user_sub_id|shop_item_id|
|:--|:--:|--:|
|1|1|1|1|
|2|1|2|2|
|3|2|1|3|
|4|1|3|4|


UserShopItemCategory
|id|user_id|shop_item_category_id|priority|
|:--|:--:|--:|
|1|1|1|1|
|2|1|2|2|
|3|2|2|1|
|4|1|3|3|


2). UserShopItemテーブルにおいて、shop_item_idをもとにShopItemテーブルからshop_item_category_idを引っ張ってくる。
さらにそのshop_item_category_idとuser_idをもとに、UserShopItemCategoryテーブルからpriorityを引っ張ってくる。
最後に、shop_item_idをもとに、ShopItemテーブルからshop_item_nameを引っ張ってくる。
すると、UserShopItemテーブルに3カラム加わり、以下のようになる。

UserShopItem
|id|user_id|user_sub_id|shop_item_id|shop_item_category_id|priority|shop_item_name|
|:--|:--:|--:|
|1|1|1|1|1|1|A'|
|2|1|2|2|2|2|B'|
|3|2|1|3|2|1|C'|
|4|1|3|4|3|3|D'|


このテーブルから、user_idが1のshop_item_nameを取り出し、priority順に表示する。つまり、以下のように表示される。

A'
B'
D'

以上が私のやりたいことです。

UserShopItemとUserShopItemCategoryのテーブルをwhereメソッドで繋ごうとしているのですが、そもそもの構築方法がよくわからずに苦戦しています。

質問が若干抽象的になってしまい、申し訳ございません。
さらに進展したらコードも追記いたしますが、構築方法のヒントだけでも教えていただけると大変助かります。
どうぞよろしくお願いいたします。

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

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

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

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

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

winterboum

2019/08/02 01:37

関連するモデル全部の has_*、berongs_to のところを開示して下さい
sage

2019/08/02 11:04

やったこと(ソース)と、どういう問題が発生しているか(エラーメッセージまたは現象)を書かないと、どこに問題があるか、だれも指摘できないのでは?
masaki5.5

2019/08/03 02:10

> winterboum, sage ご指摘ありがとうございます。再編集いたしましたが、より進展したらさらに具体的なコードも載せさせていただきます。よろしくお願いいたします。
guest

回答2

0

こういうタイプの質問は、コメントにもあるようにあまり歓迎されないのですが、
「さらに進展したらコードも追記いたしますが、構築方法のヒントだけでも」とありますし、また、Excelっぽいところから組み立て方が離れられないようですので、さわりだけ。
rubyでやるとすると、「すると、UserShopItemテーブルに3カラム加わり、以下のようになる。」というような進め方はあまりしません。

user_idが1のshop_item_nameを得るのなら
User.find(1).shop_items.map{|shop_item| shop_item.name }
とします。
関連の定義の仕方はわかっているわけですから、関連を定義すると自動的に作られるmethodについて勉強すれば展望がみえると思います

投稿2019/08/03 02:20

winterboum

総合スコア23329

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

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

masaki5.5

2019/08/03 02:33

> winterboum ご回答ありがとうございます。下手な質問をしてしまい、申し訳ございません(><) 教えて頂いたヒントをもとに取り組んでみます。ありがとうございます。
guest

0

自己解決

winterboumさんのおっしゃる通り、モデル同士の関係が複雑な場合は、テーブルをExcelのように互いに関連づけるのは難しいようです。
今回のケースは、親を共有する子モデル同士の結合(正確には子と孫)を試みていましたが、結局、片方の子モデルのデータを配列として取り出し、もう片方の子モデルに利用する方法に落ち着きました。

以下が、参考までに私が書いたコードです(初心者のため、あくまで参考ですが。。)

Ruby

1@user_priorities 2= UserShopItemCategory.where(user_id: 1).order("priority ASC").pluck(:shop_item_category_id) 3 4@user_prioritised_shop_item_categories 5= @user_priorities & UserShopItem.where(user_id: 1).joins(:shop_item).pluck(:shop_item_category_id) 6 7@user_prioritised_shop_item_categories.each_with_index do |user_prioritised_shop_item_category, i| 8 9@user_items_each_category = 10UserShopItem.where(user_id: 1).joins(:shop_item).where(shop_items: {shop_item_category_id: user_prioritised_shop_item_category}) 11 12@user_items_each_category.order("user_sub_id DESC") 13 14@user_items_each_category.each_with_index do |user_item, i| 15puts ShopItem.find(user_item.shop_item_id).name 16 17end 18 19end

色々検索しましたが、以下のリンクが最も参考になりました。
https://doruby.jp/users/maya/entries/【Rails】巨大なテーブル同士をjoinせずに検索【速度改善】

参考にしていただければと思います。どうぞよろしくお願いします。

投稿2019/08/08 11:59

masaki5.5

総合スコア10

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問