Rake任务为散列抛出错误分配默认值

时间:2012-03-19 09:28:44

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

我在模型User中有一个序列化属性首选项,如下所示:

user.preferences
=> 
 @allow_fans=true,
 @approvals={:email=>true, :message=>false},
 @comment_on_an_item={:email=>false, :message=>true},
 @community_invitations={:email=>true, :message=>true},
 @community_requests={:email=>true, :message=>true},
 @flags={:email=>true, :message=>true},
 @follows={:email=>false, :message=>true},
 @likes_and_shares={:email=>false, :message=>true},
 @make_my_email_visible=true,
 @trackbacks_pingbacks={:email=>true, :message=>false}>

我编写了一个rake任务来为现有用户分配默认首选项哈希,如下所示

namespace :user_preferences do
  desc "set default preferences for existing users"
  task :pref_defaults => :environment do
    default = {:comment_on_an_item => {'email' => nil, 'message' => true},
      :likes_and_shares => {'email' => nil, 'message' => true},
      :flags => {'email' => true, 'message' => true},
      :trackbacks_pingbacks => {'email' => true, 'message' => nil},
      :community_invitations => {'email' => true, 'message' => true},
      :approvals => {'email' => nil, 'message' => true},
      :community_requests => {'email' => true, 'message' => true},
      :follows => {'email' => nil, 'message' => true}}

    User.update_all(:preferences => default)
  end
end

但是当我运行rake任务rake user_preferences:pref_defaults时,我收到了错误

** Invoke user_preferences:pref_defaults (first_time)
** Invoke environment (first_time)
** Execute environment
** Execute user_preferences:pref_defaults
rake aborted!
PG::Error: ERROR:  syntax error at or near "'---
- :likes_and_shares
- email: 
  message: true
'"
LINE 5: ','---
          ^
: UPDATE "users" SET "preferences" = '---
- :comment_on_an_item
- email: 
  message: true
','---
- :likes_and_shares
- email: 
  message: true
','---
- :flags
- email: true
  message: true
','---
- :trackbacks_pingbacks
- email: true
  message: 
','---
- :community_invitations
- email: true
  message: true
','---
- :approvals
- email: 
  message: true
','---
- :community_requests
- email: true
  message: true
','---
- :follows
- email: 
  message: true
'

请帮我解决这个错误。

1 个答案:

答案 0 :(得分:1)

在此处查看评论:http://apidock.com/rails/ActiveRecord/Base/update_all/class

  

如果使用update_all更改标记为序列化的属性(   使用ActiveRecord :: Base.serialize),你需要调用to_yaml   自己:

User.update_all({ :preferences => { :first_name => ‘John’, :last_name  => 'Doe' }.to_yaml })