django 中外键和表的操作
外键
在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。
如果使用的是InnoDB引擎,是支持外键约束的
类定义为class ForeignKey(to,on_delete,**options)
第一个参数是引用的是哪个模型,第二个参数是在使用外键引用的模型数据被删除了,这个字段该如何处理
使用外键的表为子表,被引用的表为父表
创建数据库表
models.py
from django.db import models
class User(models.Model):
username = models.CharField('用户名', max_length=20)
class Article(models.Model):
title = models.CharField('文章主题', max_length=100)
content = models.TextField('文章内容', max_length=100)
author = models.ForeignKey("User", on_delete=models.CASCADE)
使用ForeignKey来定义模型之间的关系。
即在article的实例中可以通过author属性来操作对应的User模型。这样使用起来非常的方便
views.py
from django.shortcuts import render, HttpResponse
from test01.models import User, Article
def info(request):
# user = User(username='李四', password='123')
user = User.objects.get(id=2)
# user.save()
article = Article(title='三国', content='三国演义', author=user)
article.save()
return HttpResponse('ok')
def info_delete(request):
# article = Article.objects.get(id=1)
user = User.objects.get(id=2)
user.delete()
return HttpResponse('delete ok')
使用了ForeignKey后,就能通过author访问到对应的user对象呢。
因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),
这个字段是一个外键,记录着对应的作者的主键。
以后通过article.author访问的时候,实际上是先通过author_id找到对应的数据,然后再提取User表中的这条数据,形成一个模型
外键表内自己引用
models.py
class Commit(models.Model):
content = models.TextField('评论', default='')
origin_commit = models.ForeignKey('self', on_delete=models.CASCADE, null=True)
# 或者
#origin_commit = models.ForeignKey('Comment', on_delete=models.CASCADE, null=True)
外键删除操作
如果一个模型使用了外键。
那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定
-
CASCADE:级联操作。如果外键对应的那条数据被删除了,那么这条数据也会被删除。 #常用 -
PROTECT:受保护。即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。 -
SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。
如果设置这个选项,前提是要指定这个字段可以为空。 -
SET_DEFAULT:设置默认值。如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。
如果设置这个选项,前提是要指定这个字段一个默认值。 -
SET():如果外键的那条数据被删除了。那么将会获取SET函数中的值来作为这个外键的值。
SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。 -
DO_NOTHING:不采取任何行为。一切全看数据库级别的约束。
以上这些选项只是Django级别的dtl操作,数据库还是别依旧是RESTRICT!
author1 = models.ForeignKey("User", on_delete=models.CASCADE)
author2 = models.ForeignKey("User", on_delete=models.PROTECT)
author3 = models.ForeignKey("User", on_delete=models.SET_NULL, null=True)
author4 = models.ForeignKey("User", on_delete=models.SET_DEFAULT, null=True, default=User.objects.get(id=3))
author5 = models.ForeignKey("User", on_delete=models.SET(default_value()), null=True)
author6 = models.ForeignKey("User", on_delete=models.DO_NOTHING)

浙公网安备 33010602011771号