• django之ORM表多对多三种创建方式


    多对多三种创建方式

    1.全自动(推荐使用  *)

      优势:不需要你手动创建第三张表

      不足:由于第三张表不是你手动创建的,也就意味着第三张表字段是固定的无法做到扩展

    class Book(models.Model):
        title = models.CharField(max_length=32)
        price = models.DecimalField(max_digits=8,decimal_places=2)
        authors = models.ManyToManyField(to='Author')
    
    class Author(models.Model):
        name = models.CharField(max_length=32)

    2.纯手动(了解即可)

    自己创建第三张表

    优势:第三张可以任意的扩展字段

    不足:orm查询不方便

    class Book(models.Model):
        title = models.CharField(max_length=32)
        price = models.DecimalField(max_digits=8,decimal_places=2)
    
    
    class Author(models.Model):
        name = models.CharField(max_length=32)
                    
                    
    class Book2Author(models.Model):
        book = models.ForeignKey(to='Book')
        author = models.ForeignKey(to='Author')
        create_time = models.DateField(auto_now_add=True)

    3.半自动(推荐使用*******)

    优势:结合了全自动和纯手动的两个优点

    class Book(models.Model):
       title = models.CharField(max_length=32)
       price = models.DecimalField(max_digits=8,decimal_places=2)
       authors = models.ManyToManyField(to='Author',through='Book2Author',through_fields=('book','author'))
    # through 告诉django orm 书籍表和作者表的多对多关系是通过Book2Author来记录的
    # through_fields 告诉django orm记录关系时用过Book2Author表中的book字段和author字段来记录的
    """
    多对多字段的
    add
    set
    remove
    clear不支持
    """
                    
                    
    class Author(models.Model):
        name = models.CharField(max_length=32)
            # books = models.ManyToManyField(to='Book', through='Book2Author', through_fields=('author', 'book'))
    
    
    class Book2Author(models.Model):
        book = models.ForeignKey(to='Book')
        author = models.ForeignKey(to='Author')
        create_time = models.DateField(auto_now_add=True)
    万般皆下品,唯有读书高!
  • 相关阅读:
    个人附加作业
    个人最终总结
    结对作业--电梯调度
    VS2015安装&简单的C#单元测试
    C#程序代码分析(第三周)
    HTML学习有感
    gitlab使用有感之坚持
    学习有感

    Activity总结
  • 原文地址:https://www.cnblogs.com/s686zhou/p/11586206.html
Copyright © 2020-2023  润新知