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

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

ただいまの
回答率

89.11%

Rails/postgreSQL テーブルをまたいだデータの計算

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 93

shayashi683

score 1

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
Ruby on Rails (version 5.2.4.2)で評価システムを作っています。
PostgreSQLでデータベースを作っているのですが、テーブル間の計算機能を実装中に以下の計算が実行されないエラーが発生しました。

実行したい計算は、Elements_edu テーブルにある "faculty_student_n"と "faculty_teacher_n"を以下のように計算し、Evaluate_edu テーブルのraitio_stとしてデータベースに保存することです。なお、db/seeds.rbにてfaculty_student_nとfaculty_teacher_nはすでにデータベースに保存されており、raitio_stはカラムが空の状態です。
(計算式:raitio_st=ElementsEdu.faculty_student_n/ElementsEdu.faculty_teacher_n)

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

エラーメッセージ:なし

該当のソースコード

class EvaluateEdu < ApplicationRecord
    belongs_to :assessment, optional: true
    has_one :elements_edu

    def raitio_st
        @evaluate_edus = EvaluateEdu.all

        @evaluate_edus.each do |ratio_st|
            ratio_st = ElementsEdu.faculty_student_n/ElementsEdu.faculty_teacher_n
            EvaluateEdu.raitio_st.update()
        end
    end
end
class ElementsEdu < ApplicationRecord
    belongs_to :evaluate_edu, optional: true
end

試したこと

・def ... end 文の追加
・pメソッドを使ってどのように値が表示されるかの確認。
・テーブルの初期化

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

使用PC: Macbook Pro
環境: Visual Studio Code, Ruby on Rails 5, PostgreSQL

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

EvaluateEduモデルで一括で各レコードのratio_stをupdateしたいということだと思いますので、、、

EvaluateEduモデル

def self.update_all_ratio_st
  all.each do |evaluate_edu|
    evaluate_edu.update(ratio_st: evaluate_edu.calc_ratio_st)
  end
end

def calc_ratio_st
  elements_edu.faculty_student_n / elements_edu.faculty_teacher_n
end

実行は、EvaluateEdu.update_all_raitio_st です。

でどうでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/07/06 21:57

    その通りです。
    となりますと、やはりいただいたコードでいいということでしょうか?
    コードにエラーは出ませんが、EvaluateEduテーブルに保存するための実行方法が分からないです。

    キャンセル

  • 2020/07/07 15:52

    使う方法は先述の通りです。
    Rails consoleでもコントローラーでも、他モデルでもという感じです。
    これ以上に説明のしようがありません。。。
    ※ あなたの環境を持っているわけではなく、動作確認はしてないので、エラーが出るものに関しては申し訳ないです。

    もしかしたらクラスメソッドが初めてでイメージつかないのかもしれないですね。
    インスタンスメソッドとクラスメソッドの違いは下記などを読んでください。(ぐぐるといっぱい出てきます。)
    https://qiita.com/right1121/items/c74d350bab32113d4f3d

    キャンセル

  • 2020/07/07 17:03

    seedファイルにEvaluateEdu.update_all_raitio_st を記載して実行することができました。 本当にありがとうございます!!

    キャンセル

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

  • ただいまの回答率 89.11%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる