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

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

ただいまの
回答率

89.10%

テーブル間でのカラム値の代入方法について

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 2,084

koume

score 162

Rails5.1.1でWebアプリケーション制作の勉強中です。おかげさまでデータベース(モデル)のところまで進むことができました。
現在、テーブルを9つ作りhas_many, has_one, belongs_to で関連付けしカラム値を変更したり代入したりしたいのですが
うまく考えがまとまらないのと、変数の利用の仕方がわからず悩んでおります。やりたいことは以下になります。

疑問1,
membersテーブルでnumber1カラム値とnumber2カラム値を足した値をscoreカラムに代入したい。

class Member < ActiveRecord: :Base
member = Member.find(3)               #レコードを取り出し変数(member)に代入する。               
abc = member.number1                   #取り出したレコードのnumber1の値を変数(abc)に代入する。
xyz = member.number2                   #取り出したレコードのnumber2の値を変数(xyz)に代入する。
ghi = abc + xyz                        #代入した変数の値を加算して変数ghiに代入する。
member = Member.create(score: [ghi])   #scoreカラムに代入


・上記で使用する変数はローカル変数でよいのでしょうか?
・scoreカラムに代入する際、値を変数[ghi]で渡せる(代入できる)のでしょうか?

関連付けされたテーブル間でのカラム値の受け渡し方法について
・has_many, belongs_toで関連付けしたpointsテーブルのdata1カラムにmemberテーブルのscoreカラムの値を代入したい。

疑問2,
代入するのはmemberモデル内で行うのか?pointモデル内で行うのか?
このような場合に使うのはインスタンス変数なのかローカル変数どちらを使うのか?

#memberモデル
class Member < ActiveRecord: :Base
member = Member.find(3)               #レコードを取り出し変数(member)に代入する。 
a = member.score                       #取り出したレコードのscoreの値を変数(a)に代入する。
point = Point.create(data: [a])       #poitテーブルのdataカラムに代入


もしくは

#memberモデル
class Member < ActiveRecord: :Base
member = Member.find(3)               #レコードを取り出し変数(member)に代入する。 
@a = member.score                       #取り出したレコードのscoreの値を変数(a)に代入する。
#memberモデルで変数aにscoreカラムの値をaに代入しておいて

#pointモデル
class Point < ActiveRecord: :Base
point = Point.create(data: [@a])       #poitテーブルのdataカラムに変数@aを代入
#memberモデルで作った変数aをpointモデルで使いdataカラムに代入する。


上記のように変数aを2つのテーブルで使用することが出来るのかわからずに困っております。
テーブル間をまたいだ変数の読み込みはローカル変数ではなくインスタンス変数なのかな?と思いましたがそれも違うような気がしてます。
テーブル間をまたいだデータ(変数)のやりとり方法が知りたいです。
もっといい方法があるのであれば教えていただけないでしょうか?
宜しくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

全般にコードがおかしいのですが、投稿するときに書き換えた事による問題なのか、正しいコードの書き方を知らないせいなのかわかりません。一応想像で補完して回答書きましたが、これの意味がわからないようでしたら、ちょっと先に進みすぎているように思います。Rubyの入門書を読みつつ、Railsの入門書やRailsチュートリアルを一通りやってみて動きが理解できるようになることが必要です。

疑問1

このコードであれば、変数に保存する必要が無いです。

member = Member.find(3)
member = Member.create(score: member.number1 + member.number2)

ところでこのコード、1行目のmemberと2行目のmemberは違うものになってしまっています。やりたいのは

member = Member.find(3)
member.update(score: member.number1 + member.number2)

のような気がします。

そうであれば、scoreカラムはいらないのではと言う話になってきます。

class Member < ActiveRecord::base
  def score
    number1 + number2 
  end
end

m = Member.find(3)
m.score #=> m.number1 + m.number2 の結果が帰ってくる

> 疑問2

これも変数使う必要が無いです。

member = Member.find(3)
point = Point.create(data: member.score)

(が、Memberモデルの値をコピーして保存する、という操作自体が必要なのか疑問です。)

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/07/25 08:19

    いつも的確な回答ありがとうござます。入門書、Railsチュートリアルをもう一度じっくりやり直してみます。今後とも宜しくお願いします。

    キャンセル

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

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