zoukankan      html  css  js  c++  java
  • django基础之中介模型

    什么是中介模型

    中介模型针对的是ManyToMany(多对多)的时候第三张表的问题,

    中介模型其实指的就是我们不通过Django创建第三张表,如果自己不创建第三张表,而是由django给我们创建,那就不存在中介模型

    中介模型示例

    普通的ManyToMany示例

    1
    2
    3
    4
    5
    6
    class Book(models.Model):
        title = models.CharField(max_length=32)
        authors = models.ManyToManyField(to='Author')
     
    class Author(models.Model):
        name = models.CharField(max_length=32)

    这时候Django会自动帮我们创建地上那张表,如下:

    中介模型小示例

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    class Book(models.Model):
        ''''''
        title = models.CharField(max_length=32)
        authors = models.ManyToManyField(to='Author',through='Book2Author')
     
    class Author(models.Model):
        name = models.CharField(max_length=32)
     
    class Book2Author(models.Model):
        book_id = models.ForeignKey(to='Book')
        author_id = models.ForeignKey(to='Author')

    这时候运行manage命令后就会生成一张第三张表,如下:

    图中可以看出,Django创建ForeignKey的时候会在字段后自动添加'_id',所以,我们在写第三张表字段的时候就不用加_id了,如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    class Book(models.Model):
        ''''''
        title = models.CharField(max_length=32)
        authors = models.ManyToManyField(to='Author',through='Book2Author')
     
    class Author(models.Model):
        name = models.CharField(max_length=32)
     
    class Book2Author(models.Model):
        book_id = models.ForeignKey(to='Book')
        author_id = models.ForeignKey(to='Author')

    中介模型与Django自建表的区别

    1、中介模型的第三张表是自己创建的,所以可以自己任意添加额外的字段,而Django自创建的第三张表的字段是固定的

    2、中介模型没有add,set  , remove,clear 方法

  • 相关阅读:
    python面试的100题(12)
    python面试的100题(11)
    python面试的100题(10)
    python面试的100题(9)
    python面试的100题(8)
    python面试的100题(7)
    纯js做鼠标拖拽物体并记录鼠标位置的效果(附pageX clientX offsetX screenX的区别图)
    利用function函数做一个简易计算器(getElementById)
    JavaScript中的函数function
    初识JavaScript
  • 原文地址:https://www.cnblogs.com/jimmyhe/p/10828642.html
Copyright © 2011-2022 走看看