今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)