0
我正在使用rails 3应用程序。 我有一个问题。我将如何将数据保存到我的数据库中?我想使用日期时间数据类型将签入和签出会话保存到数据库。如何将数据从会话保存到数据库?
控制器:
def step2
@cart = current_cart
checkin = params[:checkin]
checkout = params[:checkout]
@amenities = Amenity.available(checkin, checkout)
session[:checkin] = checkin
session[:checkout] = checkout
end
观点:
<%= f.hidden_field :Transaction_Date, :value => Time.now %>
<%= f.hidden_field :rsv_type, :value => "Online" %>
<%= f.hidden_field :rsv_status, :value => "Pending" %>
<%= f.hidden_field :checkin, session[:checkin] %>
<%= f.hidden_field :checkout, session[:checkout] %>
<% end %>
即时得到这个错误:
NoMethodError
undefined method `merge' for "05/18/2011":String
帮助..请。谢谢。
从我的ApplicationController:
private
def current_cart
Cart.find(session[:cart_id])
rescue ActiveRecord::RecordNotFound
cart = Cart.create
session[:cart_id] = cart.id
cart
end
,当我把这些代码:
@cart.checkin = DateTime.strptime(session[:checkin], "%m/d/%Y %I:%M:%S %p").to_time
@cart.checkout= DateTime.strptime(session[:checkout], "%m/d/%Y %I:%M:%S %p").to_time
@cart.save
我得到引发ArgumentError无效日期的错误。 ?:(我应该怎么办使用SQL Server 2005为我的数据库IM
这里是我的车模型
级车<的ActiveRecord :: Base的 的has_many:line_items,:依赖=>:摧毁
def add_amenity(amenity_id)
current_item = line_items.where(:amenity_id => amenity_id).first
if current_item
return false
else
current_item = LineItem.new(:amenity_id => amenity_id)
line_items << current_item
end
current_item
end
def total_price
line_items.to_a.sum { |item| item.amenity.fee }
end
def payable
total_price * 0.50
end
end
即时通讯获得另一个错误。 NoMethodError未定义的方法'checkin ='for# –
Crisgine
2011-05-18 01:29:16
@Crisgine - 你必须正确定义'@ cart',比如'@cart = Cart.where(“id =?”,params [:id]) .first'。当然,这里假设你的'Cart'模型有一个'checkin'字段。 – sscirrus 2011-05-18 04:18:35
@Crisgine - 背景位 - 如果你只是做了@cart = Cart.where(“id =?”,params [:id])',你会得到一个关系,而不是一条记录。即使关系只包含一条记录,您也必须添加'first'来获取可以开始更改属性的内容。 – sscirrus 2011-05-18 05:07:40