Rails Postgres - 日期时间值不会保存到日期时间列中



我的模型有一个日期时间属性(Postgres),我正试图通过在Rails应用程序中提交表单来创建一个新记录。

我提交的表单包含该datetime属性的text_field。它以以下格式提交日期时间作为参数:

"expires"=>"07/17/2013 12:35:26 PM"

然而,一旦它进入我的模型的创建操作中的第一行代码。。。

def create
  @special_deal = SpecialDeal.new(params[:special_deal])

大多数情况下,@special_deal.expires将=nil。只有极少数情况下,它才会起作用。

我不明白为什么会发生这种事。我猜这与在datetime值中包含AM或PM有关,但我不确定。

params每次都包含过期值:

    @_params    
{"utf8"=>"✓", "authenticity_token"=>"cl1SwnHOum8d/kiGnwkDsamG5IMbmdnoeFvlY11KpKc=", "special_deal"=>{"title"=>"", "provider"=>"", "description"=>"", "deal_price"=>"", "conditions"=>"", "expires"=>"07/27/2013 14:23:59", "excerpt"=>"", "original_price"=>"", "phone_number"=>"", "street"=>"", "city"=>"", "postal_code"=>"", "state"=>"", "country"=>""}, "commit"=>"Create Special deal", "action"=>"create", "controller"=>"special_deals"}

但@special_deal没有:

    @special_deal   
#<SpecialDeal id: nil, man_servant_id: nil, category: "", title: "", excerpt: "", description: "", original_price: nil, deal_price: nil, provider: "", product_link: "", conditions: "", phone_number: "", street: "", city: "", postal_code: "", state: "", country: "", public: true, created_at: nil, updated_at: nil, expires: nil, image_file_name: nil, image_content_type: nil, image_file_size: nil, image_updated_at: nil>

由于params[:special_deal][:expires]没有有效的格式,因此它将明显设置为零。无论您的表单是否有text_field或字符串。重要的是你发送的格式,同时创建新的特别优惠。如果操作过期字段并形成标准的日期-时间格式,则代码将起作用。无论它是字符串对象还是日期时间对象。

日期时间的标准DB格式为YYYY-MM-DD HH:MM:SS

因此,在创建新的特殊交易之前,你必须操纵到期的

"expires"=>"07/17/2013 12:35:26 PM"
"expires"=>"2013-07-17 12:35:26"

在操作Meridiem时不要忘记将其考虑在内。这将解决您的问题。

试着把这些放在创建方法中:

logger.error params[:special_deal].class
logger.error params[:special_deal].to_datetime

或者使用调试器来调查它们。

它似乎没有正确转换为日期时间。

之后你会得到一个明确的提示。

最新更新