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

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

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

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

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Ruby on Rails

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

Q&A

1回答

633閲覧

rails ecサイト 合計金額計算 エラー

franseagal1

総合スコア5

Ruby

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

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Ruby on Rails

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

0グッド

0クリップ

投稿2021/03/14 22:53

今railsでecサイトを作成しています。

アプリとしてはUserが自身のバスケットにアイテムを追加し個数を選択するというもの。
躓いているところアイテムの合計を算出するところです。 

そして下のコードでBasket_Items というのが Baskets table とItems table の中間テーブルになります。

したい事:
(Items) から :price を取得し、(Basket_Items) から :quantity を取得し、:price * :quantity の式を作り合計を求めたい。
変数としては@total_price = item_price * item_quantity

エラーの部分:
rails console で試しましたが、sum(items_price * items_quantity)の部分の計算が出来ません

どなたか分かる方いらっしゃいますか?

Basket_items class CreateBasketItems < ActiveRecord::Migration[5.2] def change create_table :basket_items do |t| t.references :basket, index: true, null: false, foreign_key: true t.references :item, index: true, null: false, foreign_key: true t.integer :quantity, null: false, default: 1 t.timestamps end end end
Baskets class CreateBaskets < ActiveRecord::Migration[5.2] def change create_table :baskets do |t| t.references :user, index: true, unique: true, null: false, foreign_key: true t.timestamps end end end
Items class CreateItems < ActiveRecord::Migration[5.2] def change create_table :items do |t| t.references :admin, index: true, null: false, foreign_key: true t.string :name, null: false, index: true t.integer :price, null: false t.text :message t.string :category, index: true t.string :img t.string :Video_url t.text :discription t.timestamps end end end

///

rails console で試しましたが、sum(items_price * items_quantity)の部分の計算が出来ません basket = current_user.prepare_basket item_ids = basket.basket_items.select(:item_id) items = basket.items.where(id: item_ids) items_price = items.select(:price) items_quantity = basket.basket_items.where(item_id: item_ids).pluck(:quantity) def self.total(items_price, items_quantity) sum(items_price * items_quantity) end @total_price = basket.total(items_price, item_quantity)

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

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

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

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

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

guest

回答1

0

どんなエラーになります?
sum() というmethodあります? どこで定義してます?

basket.basket_items.map{| basket_item.item.price * basket_item.quantity }.sum
ですね。関連を定義してあれば。

投稿2021/03/15 01:18

winterboum

総合スコア23347

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問