【问题标题】:Rails Postgres - Datetime value won't save into Datetime columnRails Postgres - 日期时间值不会保存到日期时间列中
【发布时间】:2013-07-05 11:47:01
【问题描述】:

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

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

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

但是,一旦它进入我的模型的 Create 操作中的第一行代码...

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

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

我不知道为什么会这样。我猜这与在日期时间值中包含 AM 或 PM 有关,但我不确定。

params 每次都包含 expires 值:

    @_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>

【问题讨论】:

  • 请检查是否以"Time.now.strftime("%Y-%m-%d %H:%M:%S")" 格式保存日期时间。如果它正在保存这种格式,那么您可以将其保存在数据库中,并在布局中显示时将其转换为您的格式。
  • 您使用的是什么版本的导轨? 3.2可能需要将列添加到attr_accessible,4.0添加到强参数?

标签: ruby-on-rails ruby ruby-on-rails-3 postgresql


【解决方案1】:

它显然会被设置为 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 考虑在内。这将解决您的问题。

【讨论】:

  • 在红宝石中:DateTime.now.strftime('%Y-%m-%d %H:%M:%S')
【解决方案2】:

尝试将这些放在 create 方法中:

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

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

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

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

【讨论】: