2011-05-18 160 views
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 

回答

2

你并不需要在您的形式(在你的榜样最后两个hidden_​​fields)传递会话数据。一般情况下,节省您的会话数据是非常简单的。

# some controller action with @cart defined 
@cart.checkin = session[:checkin] 
@cart.checkout = session[:checkout] 
@cart.save 

确保在此会话数据中包含任何必要的验证,以保护您的系统并确保保存到数据库的数据质量高。

此外,会话数据不应该被信任的关​​键信息,绝对不使用它来存储密码,关系到你的购物车的财务数据等


关于的日期部分你的问题,这是如何将字符串日期转换为实际的日期/时间。

DateTime.strptime("2011/05/18 13:42:02", "%Y/%m/%d %H:%M:%S").to_time 
+0

即时通讯获得另一个错误。 NoMethodError未定义的方法'checkin ='for# Crisgine 2011-05-18 01:29:16

+0

@Crisgine - 你必须正确定义'@ cart',比如'@cart = Cart.where(“id =?”,params [:id]) .first'。当然,这里假设你的'Cart'模型有一个'checkin'字段。 – sscirrus 2011-05-18 04:18:35

+0

@Crisgine - 背景位 - 如果你只是做了@cart = Cart.where(“id =?”,params [:id])',你会得到一个关系,而不是一条记录。即使关系只包含一条记录,您也必须添加'first'来获取可以开始更改属性的内容。 – sscirrus 2011-05-18 05:07:40