Odoo Help

0

How to deal with cascading write?

By
Mathieu Laflamme
on 8/3/15, 6:10 PM 771 views

I did some code to update the child partner records automatically upon modification of a field, stock_owner_id. I overwrote the "write" function to achieve that.

 @api.multi
    def write(self, vals):
        """ This will overwrite children stock owner to the same as the current one.
        """
        soid = vals.get('stock_owner_id')
        
        if soid is not None:
            children = self.search([('parent_id', 'child_of', self.ids)])
            
            if children:
                children.write({'stock_owner_id': soid})
                
        result = super(Partner, self).write(vals)
        
        return result
The problem is that the "write" function is triggered for each child write and that trigger other useless queries on the database.

Any suggestion to prevent that behaviour and still update all my children in bulk?

About This Community

This platform is for beginners and experts willing to share their Odoo knowledge. It's not a forum to discuss ideas, but a knowledge base of questions and their answers.

Register

Odoo Training Center

Access to our E-learning platform and experience all Odoo Apps through learning videos, exercises and Quizz.

Test it now

Question tools

1 follower(s)

Stats

Asked: 8/3/15, 6:10 PM
Seen: 771 times
Last updated: 8/3/15, 6:10 PM