Ruby on Rails
Sunday, August 7, 2016
Thank you Colin.
-- Yes, I know about callbacks, I don't care about it in this case. I just want to clean posts and keep not more than the last 25 ones. Thank you for the tip regarding the ordering, I'll take care about that.
On Saturday, 6 August 2016 19:10:01 UTC+2, Serguei Cambour wrote:
On Saturday, 6 August 2016 19:10:01 UTC+2, Serguei Cambour wrote:
I wonder what is the best way to delete all the records of the association on a specified condition.For example, you have User model that has many Post(s). How would keep all the recent User's Posts and delete all the last Posts when a Users have more than 25 ?There is a solution like that:def self.delete_old_posts
old_posts = []
users = includes(:post)
users.each do |user|
old_posts =+ user.posts.offset(25) unless user.posts.empty?
end
old_posts.delete_all
endAny other ideas ? Thank you.
You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group.
To unsubscribe from this group and stop receiving emails from it, send an email to rubyonrails-talk+unsubscribe@googlegroups.com.
To post to this group, send email to rubyonrails-talk@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/rubyonrails-talk/5c3ba6ed-cff1-41a6-b474-49dbd5322d5f%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment