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 方法

  • 相关阅读:
    路由 懒加载 错误ChunkLoadError: Loading chunk 10 failed.
    ngzorro create创建对话框 对话框组件内 关闭父组件 create对话框
    一个解决方案对dll的引用要注意的问题
    工作流的麻烦
    winform程序中使用documentview模式的考虑
    仿淘宝网评价的五角星投票代码
    图片闪烁代码
    JS+CSS仿淘宝滑过小图预览大图代码
    JavaScript控制图片左右播放的幻灯片代码
    JavaScript实现图片旋转构成3D圆环代码
  • 原文地址:https://www.cnblogs.com/jimmyhe/p/10828642.html
Copyright © 2011-2022 走看看