django中创建外键on_delete解析

原创 2018年04月15日 10:05:46

我现在用的是django2.0.2版本,当使用models.ForeignKey设置外键,但是不添加on_delete时,总是会报错:

TypeError: __init__() missing 1 required positional argument: 'on_delete'

而django自从1.9版本之后,on_delete这个参数就必须设置了

看看官网怎么说的吧:

ForeignKey.on_delete
    当一个ForeignKey 引用的对象被删除时,Django 默认模拟SQL 的ON DELETE CASCADE 的约束行为,并且删除包含该ForeignKey的对象。这种行为可以通过设置on_delete 参数来改变。例如,如果你有一个可以为空的ForeignKey,在其引用的对象被删除的时你想把这个ForeignKey 设置为空:

user = models.ForeignKey(User, blank=True, null=True, on_delete=models.SET_NULL)

on_delete 在django.db.models中可以找到的值有:
CASCADE
级联删除;默认值。
PROTECT
抛出ProtectedError 以阻止被引用对象的删除,它是django.db.IntegrityError 的一个子类。
SET_NULL¶
把ForeignKey 设置为null; null 参数为True 时才可以这样做。
SET_DEFAULT¶
ForeignKey 值设置成它的默认值;此时必须设置ForeignKey 的default 参数。
SET()¶
设置ForeignKey 为传递给SET() 的值,如果传递的是一个可调用对象,则为调用后的结果。在大部分情形下,传递一个可调用对象用于避免models.py 在导入时执行查询:
from django.conf import settings
from django.contrib.auth import get_user_model
from django.db import models
def get_sentinel_user():
    return get_user_model().objects.get_or_create(username='deleted')[0]
class MyModel(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL,
                             on_delete=models.SET(get_sentinel_user))
DO_NOTHING¶
Take no action. 如果你的数据库后端强制引用完整性,它将引发一个IntegrityError ,除非你手动添加一个ON DELETE 约束给数据库自动(可能要用到初始化的SQL)。




版权声明: https://blog.csdn.net/liereli/article/details/79946862

Django外键的删除

转自:http://2goo.info/blog/panjj/Django/2011/04/23/515 Django 1.3版本以后,对models外键进行了扩展,记得之前models的外...
  • shanliangliuxing
  • shanliangliuxing
  • 2013-12-27 18:32:21
  • 5867

django数据模型中关于on_delete的使用

一、外键的删除 关于on_delete的总结1、常见的使用方式(设置为null)class BookModel(models.Model): """ 书籍表 """ ...
  • kuangshp128
  • kuangshp128
  • 2018-01-01 17:23:42
  • 1180

django2.0 关联表的必填on_delete参数的含义

一对多(ForeignKey) class ForeignKey(ForeignObject): def __init__(self, to, on_delete, related_name...
  • buxianghejiu
  • buxianghejiu
  • 2018-01-17 15:36:32
  • 512

django 中ForeignKey()中的on_delete参数

1.django从1.9开始ForeignKey中的on_delete参数是必须的。2.案例代码:  from django.db import modelsclass Topic(models.Mo...
  • learnpy3
  • learnpy3
  • 2018-02-27 14:33:37
  • 624

on_delete=models.CASCADE级联删除

Django2.0,Python3.6x环境 练习Django中的一对多关系,使用Foreign关键字创建多对一的关系,Foreign(外键所在类对象的名字) 比如:书籍和作者的关系 一位作者可以创作...
  • hpu_yly_bj
  • hpu_yly_bj
  • 2017-12-28 22:28:24
  • 1555

Django-2.0 ForeignKey(on_delete)

CASCADE: ⇒`级联删除。Django模拟SQL约束ON DELETE CASCADE的行为,并删除包含ForeignKey的对象。PROTECT: ⇒`防止删除被引用的对象,通过引发 Pr...
  • qq_40942329
  • qq_40942329
  • 2018-01-29 22:59:44
  • 357

[Django]orm中的外键级联删除

这里的系统环境为django1.6   os为win
  • lzz957748332
  • lzz957748332
  • 2014-10-19 20:46:46
  • 4572

关于on_delete的参数错误

        在迁移模型Entry时,运行代码python manage.py makemigrations learning_logs,报错TypeError: __init__() missin...
  • zhouyl02
  • zhouyl02
  • 2018-02-14 16:47:12
  • 361

django报错TypeError: __init__() missing 1 required positional argument: 'on_delete'

django报错 TypeError: __init__() missing 1 required positional argument: 'on_delete' 在括号内加入属性on_del...
  • Duke10
  • Duke10
  • 2018-01-12 21:07:50
  • 1101

django models层外键报错TypeError: __init__() missing 1 required positional argument: 'on_delete'

1.解决方法,添加参数:on_delete=models.CASCADE例如topic = models.ForeignKey(Topic,on_delete=models.CASCADE)...
  • learnpy3
  • learnpy3
  • 2018-03-25 21:55:39
  • 29
收藏助手
不良信息举报
您举报文章:django中创建外键on_delete解析
举报原因:
原因补充:

(最多只允许输入30个字)