示例如下:
@profiles = Profile.where(something: true)
而不是:
@profiles.each do |profile|
@some_user.tag(profile, :with => "paris, normandy")
end
是否有一种方法可以在一次调用中标记模型的所有实例,就像这样?:
@some_user.tag(@profiles, :with => "paris, normandy")
我不认为有什么现成的东西可以做到这一点,但是如果你关心性能/速度,可以直接使用Tagging模型来进行批量标记分配。
这里是针对您的用例的代码改编,您仍然需要提供profile_ids和tag_ids。
Tagging.transaction do
profile_ids.each do |pid|
tag_ids.each do |tid|
values = ["Profile", pid, tid].join(", ")
Tagging.connection.execute "INSERT INTO taggings (taggable_type, taggable_id, tag_id) VALUES (#{values}) ON DUPLICATE KEY UPDATE id=id"
end
end
end