我在模型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
'
请帮我解决这个错误。
答案 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 })