在Django框架中,有表与表间的关联时,使用命令:python manage.py makmigrations
models中的创建表的代码:
class Book(models.Model):
name=models.CharField(max_length=30)
price=models.FloatField(null=True)
sub_data = models.DateTimeField(null=True)
publish = models.ForeignKey("Publish")
class Publish(models.Model):
name = models.CharField(max_length=30)
city = models.CharField(max_length=30)
此时,执行python manage.py makmigrations
报错:TypeError: __init__() missing 1 required positional argument: 'on_delete'
解决方式:
说明:
在Django 2.0以后的版本中,需要在引用外键时在括号内加入on_delete=models,以此产生联级作用,避免两个表内数据因发生变化而不同步导致异常;
参数说明:
on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值
CASCADE:此值设置,是级联删除。
PROTECT:此值设置,是会报完整性错误。
SET_NULL:此值设置,会把外键设置为null,前提是允许为null。
SET_DEFAULT:此值设置,会把设置为外键的默认值。
SET():此值设置,会调用外面的值,可以是一个函数。
一般情况下使用CASCADE就可以了。