zoukankan      html  css  js  c++  java
  • Orm之中介模型

    什么是中介模型

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

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

    中介模型示例

    普通的ManyToMany示例

    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会自动帮我们创建地上那张表,如下:

    中介模型小示例

    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了,如下:

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

  • 相关阅读:
    MVC CONTROLS TOOLKIT
    activemq Example
    OWASP
    ActiveMQ持久化消息的三种方式
    sqlyog
    dotnet压缩
    asp.net ajax 环境 c#与js互调
    asp.net 初步入门使用正则抓取网页信息
    用ASP.NET with C# 绘制曲线图(Curve图)转
    asp.net 中使用excel组件权限设置
  • 原文地址:https://www.cnblogs.com/fu-yong/p/8798261.html
Copyright © 2011-2022 走看看