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

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

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

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

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

解決済

1回答

1392閲覧

Rails 子モデルから重複しないデータを取得したい

mongolia

総合スコア133

Ruby on Rails 5

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

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

0クリップ

投稿2020/02/14 02:49

編集2020/02/14 02:51

Rails ActiveRecordのデータ取得

モデルに従属している子モデルの重複なしリストを取得したいです。
現在は以下のようにしています。

@posts = Post.includes([:tag]).where(user_id: current_user.id) @tags = @posts.map { |p| p.tag }.uniq

@postsも@detailsもview側で利用します。

モデルの設定

class Post < ApplicationRecord belongs_to :tag end class Tag < ApplicationRecord has_one :post end

1つのPostに付けるTagは1つだけ。
そもそもmodelの関連付けがおかしいような・・・。

発生している問題

  1. Rails初心者のため、データ取得のベストプラクティスがわからず。。お教えください。

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

Rails5 MySQL

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

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

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

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

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

siruku6

2020/02/14 02:56

確認なのですが、現在どんな問題やエラーが発生しているのでしょうか? それとも、問題は無いけれどももっときれいにソースコードを書きたいということなのでしょうか??
mongolia

2020/02/14 03:04

こっちです! >それとも、問題は無いけれどももっときれいにソースコードを書きたいということなのでしょうか?? 周りでRuby/Railsを使う人がおらず、どのようなコード書くのが良いかわからないんです。
guest

回答1

0

ベストアンサー

何をもってuniq {に|と} するかなのですが、

Post と Tag が 1:1 なのですから、
@tags = @posts.map { |p| p.tag } でuniq無しでもuniqです
この場合なら @tags をわざわざ作らなくても、@tags.each{|tag| の代わりに@posts.each{|post| として post.tag で扱えばよいと思う。

Post1のtag1とpist2のtag2が(Tagとしては別物ですが)その属性の値が一緒の場合もありえるわけで、その場合もひとつだけにしたい、というのだと
@tags = @posts.map { |p| p.tag.name }.uniq
にするわけですが、すると @tags がtagの集まりではなくなるからそれで良いものかどうか。

投稿2020/02/14 08:34

winterboum

総合スコア23347

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問