如何在不立即影响数据库的情况下删除记录

mis*_*iru 5 odoo odoo-12

在一个先例问题中,我正在寻找与 ORM 中BaseModel.newcreate方法类似的方法,但不会在数据库中写入更改。

是否存在相同的方法,但行为像unlink?我想在onchange通话中从我的记录集中删除一条记录。我不希望立即删除记录,但仅当用户按下Save按钮时才删除。

非常感谢您提前!


有关我为什么需要此功能的更多信息:

我正在使用stockOdoo的模块。在 a 中Picking,我想动态更改保留产品(按唯一序列号跟踪),这意味着添加一些新产品move_line并删除一些现有产品。

我不能简单地更改,lot_id因为某些move_lineslot_id可能会保留在另一个中Picking(或者至少,我没有找到如何巧妙地做到这一点)。

通过更改lot_id或执行selected_move_id.move_line_ids.new({...})我的onchange方法,我可以添加新的。现在我想删除我不再需要的现有的。我想以与用户按下trash相应行上的图标相同的方式删除它们。

Cha*_* DZ 0

我尝试了类似的方法Odoo 12并且效果很好:

# I change the partner for testing different cases
@api.onchange('partner_id')
def onchage_p(self):
    """ remove moves have less then 5 units"""
    # create empty record set to hold valid records
    new_recs = self.env['stock.move']
    for move in self.move_ids_without_package:
        # keep only record that greater than 5
        if move.product_uom_qty > 5:
            new_recs += move

    # reassign it to the field. 
    self.move_ids_without_package = new_recs
Run Code Online (Sandbox Code Playgroud)

当我调试时, 所有保存的动作都会传递调用writestock.pickingdelete cammand[...,[2, move_id, False]]

该框架能够检测到一条记录已从原始记录中删除recordset,这就是添加该命令的原因。

因此,基本想法是创建一个recordset包含有效记录的新记录,并将其再次分配给 one2many 字段。