我想将每种产品的 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,...。我知道问题与代码有关,但不知道在哪里。你能帮助我吗?谢谢
答案 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 = 0
或record.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