【发布时间】:2011-05-18 01:04:50
【问题描述】:
我正在使用 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
帮助..请。谢谢。
来自我的应用程序控制器:
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。
这是我的购物车模型
类购物车 :destroy
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
【问题讨论】:
标签: sql ruby-on-rails sql-server-2005 ruby-on-rails-3