在odoo8中,避免重复many2many中的记录可以通过以下几种方式实现:
_sql_constraints
约束:在many2many字段的模型中,可以通过添加_sql_constraints
约束来避免重复记录。具体步骤如下:_sql_constraints
中添加一个约束,调用上述方法来检查重复记录。 例如,假设有一个模型ModelA
,其中有一个many2many字段m2m_field
,可以按照以下方式避免重复记录:
class ModelA(models.Model):
_name = 'model.a'
m2m_field = fields.Many2many('model.b', 'model_a_b_rel', 'model_a_id', 'model_b_id', string='Many2Many Field')
@api.constrains('m2m_field')
def _check_duplicate_records(self):
for record in self:
if len(record.m2m_field) != len(set(record.m2m_field.ids)):
raise ValidationError("Duplicate records found in Many2Many field!")
_sql_constraints = [
('unique_m2m_field', 'CHECK(1=1)', 'Duplicate records found in Many2Many field!')
]
在上述示例中,_check_duplicate_records
方法用于检查重复记录,如果发现重复记录,则会抛出一个验证错误。_sql_constraints
约束中的CHECK(1=1)
用于触发约束,调用上述方法进行检查。
unique
属性:在many2many字段的模型中,可以通过设置unique
属性为True
来避免重复记录。具体步骤如下:unique=True
属性。 例如,假设有一个模型ModelA
,其中有一个many2many字段m2m_field
,可以按照以下方式避免重复记录:
class ModelA(models.Model):
_name = 'model.a'
m2m_field = fields.Many2many('model.b', 'model_a_b_rel', 'model_a_id', 'model_b_id', string='Many2Many Field', unique=True)
在上述示例中,通过设置unique=True
属性,确保了many2many字段中的记录是唯一的。
@api.depends
装饰器:在many2many字段的模型中,可以通过使用@api.depends
装饰器来自动过滤重复记录。具体步骤如下:@api.depends
装饰器。self.env['model.b'].search([])
来获取所有相关记录,并通过filtered
方法过滤掉重复记录。 例如,假设有一个模型ModelA
,其中有一个many2many字段m2m_field
,可以按照以下方式避免重复记录:
class ModelA(models.Model):
_name = 'model.a'
m2m_field = fields.Many2many('model.b', 'model_a_b_rel', 'model_a_id', 'model_b_id', string='Many2Many Field')
filtered_m2m_field = fields.Many2many('model.b', compute='_compute_filtered_m2m_field', string='Filtered Many2Many Field')
@api.depends('m2m_field')
def _compute_filtered_m2m_field(self):
for record in self:
record.filtered_m2m_field = self.env['model.b'].search([('id', 'in', record.m2m_field.ids)])
_sql_constraints = [
('unique_m2m_field', 'CHECK(1=1)', 'Duplicate records found in Many2Many field!')
]
在上述示例中,通过定义计算字段filtered_m2m_field
,并使用@api.depends
装饰器,实现了自动过滤重复记录的功能。计算字段的方法_compute_filtered_m2m_field
使用self.env['model.b'].search([])
获取所有相关记录,并通过filtered
方法过滤掉重复记录。
以上是在odoo8中避免重复many2many中的记录的几种方法。根据具体需求和场景,可以选择适合的方式来实现。
算法大赛
云+社区沙龙online [技术应变力]
云+社区沙龙online [国产数据库]
云+社区沙龙online [新技术实践]
腾讯数字政务云端系列直播
云+社区沙龙online [国产数据库]
领取专属 10元无门槛券
手把手带您无忧上云