Odoo外键约束

Odoo 的模型关联是直接使用postgresql数据库的表外键。Odoo的写法如下:

    instructor_id = fields.Many2one('res.partner', string="Instructor")
    course_id = fields.Many2one('openacademy.course',
        ondelete='cascade', string="Course", required=True)

其中ondelete属性值,对应postgresql的外键约束 ON DELETE,取值说明:

NO ACTION
如果违反外键约束会产生一个错误。如果约束被延迟,那么到事务结束检查约束时如果仍然因为存在一个引用行而违反外键约束,则仍会产生错误。这是默认值。其他的动作action都不能被延迟。

RESTRICT
违反外键约束会产生一个错误。

CASCADE
级联删除或更新。分别删除一个引用行或者更新一个引用列的值。

SET NULL
设置引用列(referencing column(s))的值为null

SET DEFAULT
设置引用列为其缺省值。如果缺省值不是null,那么仍然需要被引用表中有一条记录的被引用字段的值与之匹配,否则操作会失败。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,898评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 9,232评论 0 11
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,308评论 19 139
  • ·错误:1000 SQLSTATE: HY000 (ER_HASHCHK)消息:hashchk·错误:1001 S...
    Catke阅读 5,530评论 0 2
  • 今天在朋友圈时看到同事发的信息了,她爸过逝了,因为白血病,她很难过。她爸的年龄没有很大,还不到60岁。我的朋友圈中...
    长风09阅读 2,532评论 0 0