栏目分类:
子分类:
返回
终身学习网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
终身学习网 > IT > 软件开发 > 后端开发 > Python

【Django实战】创建多对多关系表的三种模式及优缺点分析

Python 更新时间:发布时间: 百科书网 趣学号

我是一个甜甜的大橙子,欢迎关注✉️!
我相信技术的力量
努力将所学分享给大家
你的点赞❤️分享收藏就是对我最大的鼓励!

文章目录
  • 第一种:通过ManyToManyField自动创建
  • 第二种:手动创建
  • 第三种:使用through=…模型

第一种:通过ManyToManyField自动创建
class Book(models.Model):
    name = models.CharField(max_length=32)
    # 第一种自动创建
    authors = models.ManyToManyField(to='Author')
   

class Author(models.Model):
    name = models.CharField(max_length=32)
  • 优点:自动创建多对多关系表
  • 缺点:不能在多对多关系表上添加字段
第二种:手动创建
class Book(models.Model):
    name = models.CharField(max_length=32)


class Author(models.Model):
    name = models.CharField(max_length=32)


# 手动创建第三张表
class BookAuthor(models.Model):
    book = models.ForeignKey(to='Book')
    author = models.ForeignKey(to='Author')
    state = models.CharField()
  • 优点:克服了第一种方法的缺点,可以自行添加字段
  • 缺点:不能使用ORM方式查询
第三种:使用through=…模型

最简单和最优雅的方法是使用through=…模型,这最终将需要最少的工作来保持数据同步。

class Book(models.Model):
    name = models.CharField(max_length=32)
    author = models.ManyToManyField(to='Author',through='BookAuthor',through_fields=('book','author'))


class Author(models.Model):
    name = models.CharField(max_length=32)


class BookAuthor(models.Model):
    book = models.ForeignKey(to='Book')
    author = models.ForeignKey(to='Author')
    info = models.CharField(max_length=32)
转载请注明:文章转载自 www.051e.com
本文地址:http://www.051e.com/it/925492.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 ©2023-2025 051e.com

ICP备案号:京ICP备12030808号