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

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

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

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

Q&A

解決済

1回答

1054閲覧

ユーザーのメッセージやコメント等をまとめて並び替えたい

kawayannn

総合スコア5

Ruby on Rails

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

0グッド

0クリップ

投稿2020/02/08 12:28

編集2020/02/08 13:26

前提・実現したいこと

ruby '2.5.3' rails'5.2.2'
Railsでポートフォリオ作成中で現在、ユーザーの最近の動向を「アクティビティ」として表現しようとしています。
メッセージとコメントを混ぜてcreated_at順に並べようとして失敗しているので何が原因か教えて頂けますでしょうか。

発生している問題・エラーメッセージ

NoMethodError in Users#show undefined method `order'

該当のソースコード

users_contoroller.rb

ruby

1def show 2 @user = User.find(params[:id]) 3 @comments = @user.comments 4 @messages = @user.messages 5 @activity = [] 6 @activity = @comments + @messages 7end

show.html.haml

.activity - @activity.order(created_at: :desc).each do |active| .active - if activ.has_attribute?(:content) = active.content - elsif activ.has_attribute?(:text) = active.text

ターミナル

NoMethodError in Users#show undefined method `order' ターミナル [2] pry(#<UsersController>)> @activity => [#<Comment:0x00007ff881696dc0 id: 2, text: "記事へのコメント", user_id: 7, article_id: 11, created_at: Wed, 29 Jan 2020 01:38:34 JST +09:00, updated_at: Wed, 29 Jan 2020 01:38:34 JST +09:00>, #<Comment:0x00007ff8816405d8 id: 3, text: "aaa", user_id: 7, article_id: 11, created_at: Wed, 29 Jan 2020 01:53:32 JST +09:00, updated_at: Wed, 29 Jan 2020 01:53:32 JST +09:00>, #<Comment:0x00007ff881637fa0 id: 4, text: "!?!?", user_id: 7, article_id: 11, created_at: Wed, 29 Jan 2020 01:56:58 JST +09:00, updated_at: Wed, 29 Jan 2020 01:56:58 JST +09:00>, #<Comment:0x00007ff881637870 id: 5, text: "いいい", user_id: 7, article_id: 11, created_at: Sat, 01 Feb 2020 01:06:43 JST +09:00, updated_at: Sat, 01 Feb 2020 01:06:43 JST +09:00>, #<Comment:0x00007ff8816370c8 id: 6, text: "コメント", user_id: 7, article_id: 11, created_at: Mon, 03 Feb 2020 19:11:25 JST +09:00, updated_at: Mon, 03 Feb 2020 19:11:25 JST +09:00>, #<Message:0x00007ff880cfc468 id: 4, content: "ああ", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 00:59:45 JST +09:00, updated_at: Wed, 29 Jan 2020 00:59:45 JST +09:00>, #<Message:0x00007ff88131be48 id: 5, content: "??", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 01:14:53 JST +09:00, updated_at: Wed, 29 Jan 2020 01:14:53 JST +09:00>, #<Message:0x00007ff88131af48 id: 6, content: "!!!", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 01:56:12 JST +09:00, updated_at: Wed, 29 Jan 2020 01:56:12 JST +09:00>, #<Message:0x00007ff88131a138 id: 7, content: "何故", group_id: 3, user_id: 7, created_at: Wed, 29 Jan 2020 01:57:34 JST +09:00, updated_at: Wed, 29 Jan 2020 01:57:34 JST +09:00>, #<Message:0x00007ff881319198 id: 8, content: "あああ", group_id: 3, user_id: 7, created_at: Sat, 01 Feb 2020 01:06:15 JST +09:00, updated_at: Sat, 01 Feb 2020 01:06:15 JST +09:00>, #<Message:0x00007ff88130fb98 id: 9, content: "メッセージ", group_id: 3, user_id: 7, created_at: Mon, 03 Feb 2020 19:11:04 JST +09:00, updated_at: Mon, 03 Feb 2020 19:11:04 JST +09:00>]

user.rb

has_many :articles, dependent: :destroy has_many :comments, dependent: :destroy has_many :messages, dependent: :destroy #中略 has_many :group_users, dependent: :destroy has_many :groups, through: :group_users

article.rb

belongs_to :user has_many :comments, dependent: :destroy

comment.rb

belongs_to :user belongs_to :article

group.rb

has_many :group_users, dependent: :destroy has_many :users, through: :group_users has_many :messages

message.rb

belongs_to :group belongs_to :user

試したこと

show.html.haml

- @activity.each do |active| = active.created_at

にするとcreated_at自体は表示がされますが
当然ターミナルの順番どうりComment→Messageの順番でしか取り出せません。

他モデル間で配列を混ぜる時に何かしらのルールに引っかかっているのでしょうか
また全く別の方法でこんな方法がある、ここの知識が不足している等も含めてアドバイスをお願いします。

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

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

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

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

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

winterboum

2020/02/08 12:51

User,Comment,Messageの関連が判る様にモデルのcodeを載せてください
kawayannn

2020/02/08 13:26

追加いたしました
guest

回答1

0

ベストアンサー

MessageとCommentをごや混ぜにして表示するということは、データの持ち方が同じでなければなりませんが、そうなっているものと考えます。
複数のtableをまとめて一つにして検索するというのは、生SQLならできるのかな、と思いますが、Railsで行えるか、私には自信ありません。
幸い「あるユーザの」でそう数が多くはなさそうですから、railsに取り込んでからsortするのがわかりやすいでしょう。
@activity = (@comments + @messages).sort_by{|obj| obj.created_at}.reverse

`.activity

  • @activity.each do |active|

`

投稿2020/02/08 13:54

winterboum

総合スコア23333

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

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

kawayannn

2020/02/15 15:08

ありがとうございます。 sort_byで思い通りに動かす事ができました。 調べたところとても便利そうなメソッドで知れて良かったです。 返信、お礼が遅くなってしまい申し訳ありませんでした
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問