Django在执行python manage.py makemigr时,报 __init__() missing 1 required positional argument: 'on_delete'

Django在执行makemigrations时遇到错误,原因是从2.0版本开始,定义外键和一对一关系时必须指定'on_delete'参数。解决方案是添加'on_delete=models.CASCADE',以避免数据不一致问题。了解on_delete的五个可选值:CASCADE、PROTECT、SET_NULL、SET_DEFAULT和SET()及其含义,通常使用CASCADE即可。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Django在根据models生成数据库表时报 __init__() missing 1 required positional argument: 'on_delete'

model.py中:

class BlogArticles(models.Model):
    title = models.CharField(max_length=300)
    author = models.ForeignKey(User, related_name="blog_posts")
    body = models.TextField()
    publish = models.DateTimeField(default=timezone.now)

报错 :

D:\py\platform\platform\mysite>python manage.py makemigrations
Traceback (most recent call last):
  File "manage.py", line 15, in <module>
    execute_from_command_line(sys.argv)
  File "D:\Program Files (x86)\Python\Python36\lib\site-packages
\django\core\management\__init__.py", line 381, in execute_from_
command_line
    utility.execute()

。。。

  File "D:\py\platform\platform\mysite\blog\models.py", line 9,
in <module>
    class BlogArticles(models.Model):
  File "D:\py\platform\platform\mysite\blog\models.py", line 11, in BlogArticles
    author = models.ForeignKey(User, related_name="blog_posts")
TypeError: __init__() missing 1 required positional argument: 'on_delete'

解决办法:

将报错行(第3行)代码改为:

author = models.ForeignKey(User, related_name="blog_posts", on_delete=models.CASCADE,)
即在外键值的后面加上 on_delete=models.CASCADE

原因:

在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错:
      TypeError: __init__() missing 1 required positional argument: 'on_delete'
举例说明:
     user=models.OneToOneField(User)
     owner=models.ForeignKey(UserProfile)
需要改成:
     user=models.OneToOneField(User,on_delete=models.CASCADE) --在老版本这个参数(models.CASCADE)是默认值
     owner=models.ForeignKey(UserProfile,on_delete=models.CASCADE) --在老版本这个参数(models.CASCADE)是默认值
参数说明:
     on_delete有CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET()五个可选择的值
     CASCADE:此值设置,是级联删除。
     PROTECT:此值设置,是会报完整性错误。
     SET_NULL:此值设置,会把外键设置为null,前提是允许为null。
     SET_DEFAULT:此值设置,会把设置为外键的默认值。
     SET():此值设置,会调用外面的值,可以是一个函数。
一般情况下使用CASCADE就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值