Odoo----constraints 使用

it2026-01-27  4

Odoo中的约束

一:装饰器约束(字段约束)

装饰器参数指定了约束的字段,当涉及的字段中任一发生改变时触发方法执行。如果不满足约束条件,该方法将引发异常。

@api.constrains('约束字段') def _check_something(self): for record in self: if record.约束字段 op 值: raise ValidationError("异常信息")

Constraints:

@api.constrains('instructor_id', 'attendee_ids') def _check_instructor_not_in_attendees(self): for r in self: if r.instructor_id and r.instructor_id in r.attendee_ids: raise exceptions.ValidationError("A session's instructor can't be an attendee")

odoo的Constraints,是通过装饰器@api.constrains(字段),每次记录修改的时候,如果包含了装饰器定义的字段就会触发下面的方法,所以需要在方法里面判断是否违反约束,如果违反,则通过raise异常来弹出警告框并阻止记录保存。使用odoo Constraints的时候就算是系统内已经有违反约束的记录也可以对新记录生效。

二:代码约束(函数约束,代码层面的约束)

@api.multi def _check_XX(self): //字段校验函数 if ...: return False return True _constraints = [ (_check_XX, u'约束异常信息!', ['约束的字段', ...]),]

三:Sql约束(数据库层面的约束)

sql约束:使用_sql_constraints属性。

属性值是一个列表,每一个列表元素有三个内容:(name, sql_definition, message):

name是约束名,

sql_definition是一个postgresql语句,可以为uniqe检查、或者用聚集函数判断某字段值等等,结果返回值是布尔类型即可,

message是校验失败时返回的错误消息。

_sql_constraints = [ ('约束名', 'postgresql校验语句', u'报错信息!') ]

例如,唯一性约束:

_sql_constraints = [ ('xx_uniq', 'unique (唯一性的字段,可以多个字段复合)', u'存在重复的内容!') ]

注意在使用SQL Constraints,需要确保当前数据库里面没有违反该约束的数据,如果有违反约束的数据在更新模块的时候系统日志里面会有警告信息,大家要注意这个。

最新回复(0)