django框架model中外键问题

一、解决django框架model中外键不落实到数据库问题
在外键字段的参数中添加db_constraint=False即可,
数据库中没有外键关系,代码中依然可以按照正常外键方式使用。

django中的ForeignKey与数据库中FOREIGN KEY约束并不一样,
ForeignKey是一种逻辑上的关联关系,是否使用数据库中的外键约束通过db_contraint参数设置

二、django之on_delete
on_delete=None, # 删除关联表中的数据时,当前表与其关联的field的行为
on_delete=models.CASCADE, # 删除关联数据,与之关联也删除
on_delete=models.DO_NOTHING, # 删除关联数据,什么也不做
on_delete=models.PROTECT, # 删除关联数据,引发错误ProtectedError
#models.ForeignKey(‘关联表’, on_delete=models.SET_NULL, blank=True, null=True)
on_delete=models.SET_NULL, # 删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空,一对一同理)
#models.ForeignKey(‘关联表’, on_delete=models.SET_DEFAULT, default=‘默认值’)
on_delete=models.SET_DEFAULT, # 删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值,一对一同理)
on_delete=models.SET, # 删除关联数据,
a. 与之关联的值设置为指定值,设置:models.SET(值)
b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)

三、不管是外键,还是多对多,多对一键等各种情况,都是靠主键来建立对应关系。

普通数据项:直接插入
外键数据项:先获取要插入的外键,然后和普通想一起插入
多对多数据项:获取要插入的多对多数据项,待表中普通数据项和外键数据项save后,使用.add方法加入

你可能感兴趣的:(django,python,后端)