Odoo 11:在sale.order.line模型中创建计算字段时出现问题

时间:2019-01-24 14:34:55

标签: python-3.x field odoo odoo-11

我想将每种产品的 bom_id 放入sale.order.line模型中,为此,我使用计算字段来获取Bom ID(mrp.bom)。对于特定的开发,我需要这样做,其目标是在进行生产之前根据公司的计算显示已消耗的材料。这是代码:

bom_id = fields.Integer(
    string='Bom ID',
    compute='_get_bom_id'
)

@api.multi
def _get_bom_id(self):
    bom_obj = self.env['mrp.bom']
    for record in self:
        bom_obj_id = bom_obj.search([('product_id', '=', record.product_id.id)])
        if bom_obj_id:
            record.bom_id = bom_obj_id.id
        else:
            record.bom_id = 0

问题在于该字段不是在sale.order.line模型中创建的,但是如果我删除了compute参数,它将起作用。我已经更新了模块,签入pgadmin,...。我知道问题与代码有关,但不知道在哪里。你能帮助我吗?谢谢

1 个答案:

答案 0 :(得分:1)

您创建的字段类型错误,应为 Many2one 而不是 Integer

bom_id = fields.Many2one(
    comodel_name='mrp.bom',
    string='Bom ID',
    compute='_get_bom_id'
)

您还忘记了api.depends装饰器。对于您而言,每次字段product_id更改时都应重新计算该值。

此外,计算字段在执行其计算方法之前总是将值False赋值,因此,如果在您的计算方法中,工作流没有为该字段赋值,则它仍将值False赋值,这意味着record.bom_id = 0record.bom_id = False之类的行是无用的。

@api.multi
@api.depends('product_id')
def _get_bom_id(self):
    bom_obj = self.env['mrp.bom']
    for record in self:
        bom_obj_id = bom_obj.search([('product_id', '=', record.product_id.id)])
        if bom_obj_id:
            record.bom_id = bom_obj_id.id