Django2.0里model外键和一对一的on_delete参数
在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就可以了。
下面是官方文档说明:
ForeignKey
accepts other arguments that define the details of how the relation works.
ForeignKey.
on_delete
¶-
When an object referenced by a
ForeignKey
is deleted, Django will emulate the behavior of the SQL constraint specified by theon_delete
argument. For example, if you have a nullableForeignKey
and you want it to be set null when the referenced object is deleted:user = models.ForeignKey( User, models.SET_NULL, blank=True, null=True, )
Deprecated since version 1.9:
on_delete
will become a required argument in Django 2.0. In older versions it defaults toCASCADE
.
The possible values for on_delete
are found in django.db.models
:
PROTECT
[source]¶-
Prevent deletion of the referenced object by raising
ProtectedError
, a subclass ofdjango.db.IntegrityError
.
SET_NULL
[source]¶-
Set the
ForeignKey
null; this is only possible ifnull
isTrue
.
SET_DEFAULT
[source]¶-
Set the
ForeignKey
to its default value; a default for theForeignKey
must be set.
SET
()[source]¶-
Set the
ForeignKey
to the value passed toSET()
, or if a callable is passed in, the result of calling it. In most cases, passing a callable will be necessary to avoid executing queries at the time your models.py is imported: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
[source]¶-
Take no action. If your database backend enforces referential integrity, this will cause an
IntegrityError
unless you manually add an SQLON DELETE
constraint to the database field.
ForeignKey.
limit_choices_to
¶-
Sets a limit to the available choices for this field when this field is rendered using a
ModelForm
or the admin (by default, all objects in the queryset are available to choose). Either a dictionary, aQ
object, or a callable returning a dictionary orQ
object can be used.For example:
staff_member = models.ForeignKey( User, on_delete=models.CASCADE, limit_choices_to={'is_staff': True}, )
causes the corresponding field on the
ModelForm
to list onlyUsers
that haveis_staff=True
. This may be helpful in the Django admin.The callable form can be helpful, for instance, when used in conjunction with the Python
datetime
module to limit selections by date range. For example:def limit_pub_date_choices(): return {'pub_date__lte': datetime.date.utcnow()} limit_choices_to = limit_pub_date_choices
If
limit_choices_to
is or returns aQ object
, which is useful for complex queries, then it will only have an effect on the choices available in the admin when the field is not listed inraw_id_fields
in theModelAdmin
for the model.Note
If a callable is used for
limit_choices_to
, it will be invoked every time a new form is instantiated. It may also be invoked when a model is validated, for example by management commands or the admin. The admin constructs querysets to validate its form inputs in various edge cases multiple times, so there is a possibility your callable may be invoked several times.