我正在建立一个商店,其中包含每个用户的商品和订单。 现在我想将每个订单与current_user相关联。也就是说,正在下订单。 我想到了如何关联模型,但我无法弄清楚在创建订单时会将user_id保存到订单模型的内容。我使用标准的Devise引擎。
这些是我的模特:
Order.rb
belongs_to :order_status
belongs_to :user
has_many :order_items
before_create :set_order_status
before_save :update_subtotal
def subtotal
order_items.collect { |oi| oi.valid? ? (oi.quantity * oi.unit_price) : 0 }.sum
end
private
def set_order_status
self.order_status_id = 1
end
def update_subtotal
self[:subtotal] = subtotal
end
end
order_item.rb
class OrderItem < ActiveRecord::Base
belongs_to :product
belongs_to :order
validates :quantity, presence: true, numericality: { only_integer: true, greater_than: 0 }
validate :product_present
validate :order_present
before_save :finalize
def unit_price
if persisted?
self[:unit_price]
else
product.price
end
end
def total_price
unit_price * quantity
end
private
def product_present
if product.nil?
errors.add(:product, "is not valid or is not active.")
end
end
def order_present
if order.nil?
errors.add(:order, "is not a valid order.")
end
end
def finalize
self[:unit_price] = unit_price
self[:total_price] = quantity * self[:unit_price]
end
end
在user.rb中,我有:has_one :order
这是我的OrderItemsController:
class OrderItemsController < ApplicationController
def create
@order = current_order
@order_item = @order.order_items.new(order_item_params)
@order.save
session[:order_id] = @order.id
end
def update
@order = current_order
@order_item = @order.order_items.find(params[:id])
@order_item.update_attributes(order_item_params)
@order_items = @order.order_items
end
def destroy
@order = current_order
@order_item = @order.order_items.find(params[:id])
@order_item.destroy
@order_items = @order.order_items
end
private
def order_item_params
params.require(:order_item).permit(:quantity, :product_id)
end
end
答案 0 :(得分:1)
如何将用户与订单相关联。用户应该有很多订单。首先,您是否已编写迁移以向订单表中添加user_id
列?通过引用创建一个:rails g migration AddUserToOrder user:references
然后更新您允许的参数,以便允许user_id
。
从那里你可以选择做一些事情......你可以在保存前在订单控制器的创建动作中设置user_id
。 (相关但不是你的Q - 你需要order_item的order_id,不是吗?)或者,您可以通过隐藏字段传递表单中的user_id。
其中任何一个都会将它与您联系起来。
答案 1 :(得分:0)
您可以像这样分配:
current_user.order = @order
current_user.save
如果您希望用户下线has_many,则为:
current_user.orders << @order