有没有办法检查Many2one res.users记录是否已经存在

时间:2019-08-07 20:40:09

标签: python-3.x odoo-12

  

我正在创建自己的模块来管理odoo中的代理帐户。我确实需要验证res.user是否已在代理中,以避免使用相同的res.user帐户创建代理

class Agent(models.Model):
    _name = 'agent.a'

    agent_id = fields.Many2one(
        'res.users',
        string='Agent',
        default=lambda s: s.env.user)
    agent_image = fields.Binary(string='Photo')
    local_id = fields.One2many('local.n', 'Localisation_Af', string='Localisation')
@api.model
    def create(self, vals):
        res = super(Agent, self).create(vals)
        modelObj = self.env['agent.a']

        for record in res:
          rec = modelObj.search([('agent_id', '=', record.agent_id.login)])
            if rec:
               raise ValidationError(('Already exists'))
            else:
                return res
  

但是结果总是True

1 个答案:

答案 0 :(得分:0)

请使用以下代码进行检查

@api.model
def create(self, vals):
    if vals.get('agent_id',False):
        modelObj = self.env['agent.a']
        rec = modelObj.search([('agent_id', '=', vals.get('agent_id',False))])
        if rec:
           raise ValidationError(('Already exists'))
    return super(Agent, self).create(vals)

请注意,我们无法在不是正确方法的create中循环执行res,并且在您的代码中,您在创建记录后正在检查条件,因此搜索结果始终为true。