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

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

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

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

MySQL

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

Ruby on Rails

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

Q&A

解決済

2回答

673閲覧

ruby データをuserと紐づけて、紐づいたuserの値のみを出力させたい

branchpeach

総合スコア12

Ruby

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

MySQL

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

Ruby on Rails

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

0グッド

0クリップ

投稿2021/04/05 08:28

編集2021/04/05 08:32

前提・実現したいこと

家計簿のアプリケーションを作成していて、収入や支出を登録した後に登録したデータを一覧表示にさせるのですが、
データベースのデータとuserを紐づけて、紐づけたuserのデータのみを出力させたい。
現段階ではどのuserでも一覧表示のデータが変わらない。

発生している問題

イメージ説明
どのユーザーでもこのような一覧表示がされ、userとデータが紐づいていないと考えています。

該当のソースコード

ruby

1incomes controller 2 3class IncomesController < ApplicationController 4 before_action :authenticate_user! 5 before_action :income_id, only: [:show, :edit, :update, :destroy] 6 before_action :income_user, only: [:index, :search] 7 before_action :spending_user, only: [:index,:search, :show] 8 before_action :move_to_index, only: [:show, :edit, :destroy, :update, :create] 9 require "time" 10 11 def index 12 @spendings_time = Spending.where(date: Time.now.beginning_of_month..Time.now.end_of_month).includes(:user).order(date: "ASC") 13 @incomes_time = Income.where(date: Time.now.beginning_of_month..Time.now.end_of_month).includes(:user).order(date: "ASC") 14 @spending_sum = @spendings_time.sum(:price) 15 @income_sum = @incomes_time.sum(:price) 16 @expense_sum = @income_sum - @spending_sum 17 @spending_data = Spending.all.where(date: Time.now.beginning_of_month..Time.now.end_of_month) 18 @this_month = Time.new.month 19 end 20 21 def new 22 @income = Income.new 23 end 24 25 def create 26 @income = Income.new(income_params) 27 if @income.save 28 redirect_to root_path 29 else 30 render :new 31 end 32 end 33 34 def show 35 end 36 37 def edit 38 end 39 40 def update 41 if @income.update(income_params) 42 redirect_to root_path 43 else 44 render :edit 45 end 46 end 47 48 def destroy 49 @income.destroy 50 redirect_to root_path 51 end 52 53 def search 54 end 55 56 private 57 def income_params 58 params.require(:income).permit(:price, :category, :memo, :date).merge(user_id: current_user.id) 59 end 60 def income_id 61 @income = Income.find(params[:id]) 62 end 63 def income_user 64 @incomes = Income.includes(:user).order(date: "ASC") 65 end 66 def spending_user 67 @spendings = Spending.includes(:user).order(date: "ASC") 68 end 69 def move_to_index 70 if current_user.id != @income.user.id 71 redirect_to root_path 72 end 73 end 74end 75 76 77

ruby

1index.html.erb 2 3<div class="center-content"> 4 <div class="title"><%= @this_month %>月の収入</div> 5 <div class="post-list-content"> 6 <% @incomes_time.each do |income| %> 7 <ul class="post-list"> 8 <li class="post-list-data-date"><%= income.date %></li> 9 <ul> 10 <li><%= link_to '詳細', income_path(income.id), class:"link_pass" %></li> 11 <li><%= link_to '編集', edit_income_path(income.id), class:"link_pass" %></li> 12 <li><%= link_to '削除', income_path(income.id), class:"link_pass", method: :delete %></li> 13 </ul> 14 <li class="post-list-data"><%= income.category %></li> 15 <li class="post-list-data"><%= image_tag 'money.png', size: '50x50' %>¥<%= income.price %></li> 16 </ul> 17 <% end %> 18 </div> 19 </div>

ruby

1incomeモデル(収入) 2 3class Income < ApplicationRecord 4 with_options presence: true do 5 validates :price, inclusion: { in: 1..100000000 }, format: {with: /\A[0-9]+\z/}, numericality: true 6 validates :category 7 validates :memo 8 validates :date 9 end 10 11 def start_time 12 self.date 13 end 14 15 16 17 18 belongs_to :user 19end 20 21

ruby

1spendingモデル(支出) 2 3class Spending < ApplicationRecord 4 with_options presence: true do 5 validates :price, inclusion: { in: 1..100000000 }, format: {with: /\A[0-9]+\z/}, numericality: true 6 validates :category 7 validates :memo 8 validates :date 9 end 10 11 def start_time 12 self.date 13 end 14 15 16 belongs_to :user 17end 18

試したこと

@incomes_time = Income.where(date: Time.now.beginning_of_month..Time.now.end_of_month).includes(:user).order(date: "ASC")

  • この記述で、includes:userとしているのでuserと紐づているデータが取得できていると思う。(incomes controller)

  • そして、<% @incomes_time.each do |income| %>とすることで該当する月のuserと紐づくデータをeachメソッドで出力させている。(index.html.erb)

  • <%= income.category %>, <%= income.date %>, <%= income.price %>で3つのデータを出力させている。

  • incomesコントローラーの以下の記述でuserと紐づく値が取得できていない?

@incomes_time = Income.where(date: Time.now.beginning_of_month..Time.now.end_of_month).includes(:user).order(date: "ASC")

どなたかご教授いただけると幸いです。

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

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

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

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

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

guest

回答2

0

ベストアンサー

@incomes_time = Income.where( )
に追加して
@incomes_time = Income.where( ).where(user_id: 表示するUser.id)
としてください。

投稿2021/04/05 09:49

winterboum

総合スコア23329

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

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

branchpeach

2021/04/05 10:00

ご回答ありがとうございます。 つまり、`@incomes_time = Income.where(date: Time.now.beginning_of_month..Time.now.end_of_month).includes(:user).order(date: "ASC")` の書き方だとuserが紐づいていないということでしょうか? <% if current_user.id == income.user.id %>を追記するとうまく行きました。
winterboum

2021/04/05 11:26

紐づく の意味がはっきりしないのですが。。。 Income と User は モデルでの has_many、belongs_toによって紐付いてます。 includes(:user) は 1+N問題解決のためのものです。 「解決した方法」には問題があります。 このシステムのユーザーが10万人に増え対象期間のIncomeが1000万件になると、それ全部をDBから取り出して、その中の1/10万だけ使うというDBにもOSにも負担のかかる方法になります。where(user_id: current_user.id)とすれば、DBからはそのユーザーのものだけ取り出してくるので負担が減ります。
branchpeach

2021/04/05 11:42

ご回答ありがとうございます。 DBの負担はそこまで考えていませんでした。 大変勉強になりました、ありがとうございます。
guest

0

<% if current_user.id == income.user.id %>とすることでuserとincomeで紐づいているものだけが出力されるようになりました。

投稿2021/04/05 10:04

branchpeach

総合スコア12

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問