我在我的网站上为我的用户消息传递线程功能使用“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方法时,我怎么能这样做以便忽略这个父行?
亲切的问候