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来指定

  1. CASCADE:级联操作。如果外键对应的那条数据被删除了,那么这条数据也会被删除。 #常用

  2. PROTECT:受保护。即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。

  3. SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。
    如果设置这个选项,前提是要指定这个字段可以为空。

  4. SET_DEFAULT:设置默认值。如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。
    如果设置这个选项,前提是要指定这个字段一个默认值。

  5. SET():如果外键的那条数据被删除了。那么将会获取SET函数中的值来作为这个外键的值。
    SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。

  6. 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)
posted @ 2020-12-26 13:52  qqaazzhf  阅读(343)  评论(0)    收藏  举报