ruby-on-rails – 除了ruby on rails之外,我将如何destroy_all或delete_all记录?

我在我的网站上为我的用户消息传递线程功能使用“acts_as_tree”插件.我有一个方法可以删除选定的消息.消息实际上不会被删除.其sender_status或recipient_status列设置为1,具体取决于用户邮件的发件人或收件人.

无论如何,如果两个用户都将这些状态设置为1,则最后一行确保消息行完全从数据库移出.现在这很好,只要它不是父信息被删除.如果父邮件删除,则将无法再访问尚未选择删除的子邮件.

这是方法

def delete_all_users_selected_messages(message_ids,user_id,parent_id)
          Message.where(:id => message_ids,:sender_id => user_id).update_all(:sender_status => 1)
          Message.where(:id => message_ids,:recipient_id => user_id).update_all(:recipient_status => 1)
          Message.delete_all(:sender_status => 1,:recipient_status => 1,:parent_id => parent_id).where("id != ?",parent_id)
        end

我正在努力做的很明显.我需要忽略父级.因此,主键等于parent_id意味着该行是父(通常,parent_id是nil,但我需要将其设置为主键值,因为其他原因,长篇故事并不重要).无论如何是否有一个sql语句我可以添加到tat方法的最后一行的末尾?要确保它只删除行的id不等于parent_id的消息?

除非删除实际线程(引用消息表对话的MessageThreads表),否则我可以安排从不允许删除parent_id行.

在运行delete_all方法时,我怎么能这样做以便忽略这个父行?

亲切的问候

解决方法

如今在Rails 4中,您可以:
Model.where.not(attr: "something").delete_all

Model.where.not(attr: "something").destroy_all

不要忘记差异:

> destroy_all:通过调用destroy方法将相关对象与此对象一起销毁.实例化所有记录并一次销毁一个,因此对于大型数据集,这可能会很慢> delete_all:立即销毁所有关联对象,而不调用其destroy方法.不调用回调.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...