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

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

第一种:通过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)
相关文章
|
1天前
|
前端开发 JavaScript BI
Django教程第5章 | Web开发实战-数据统计图表(echarts、highchart)
使用echarts和highcharts图表库实现折线图、柱状图、饼图和数据集图
71 2
|
1天前
|
SQL 数据库 索引
Django MTV - 模型层 - (专题)知识要点与实战案例
Django MTV - 模型层 - (专题)知识要点与实战案例
33 0
|
8月前
|
中间件 API 数据库
Python Django Web开发实战
Python Django Web开发实战
72 0
|
1天前
|
XML JSON 前端开发
Django视图函数技巧,从入门到实战
Django视图函数技巧,从入门到实战
|
1天前
|
Python
使用Django时,如何设计模型关系(一对一、一对多、多对多)?
Django支持三种模型关联:ForeignKey(一对多),OneToOneField(一对一)和ManyToManyField(多对多)。ForeignKey示例:`Article`有一个指向`Author`的外键。OneToOneField示例:`UserProfile`与`User`一对一关联。ManyToManyField示例:`Student`和`Course`之间多对多关系。这些关联字段便于反向查询,如`article.author`获取作者,`author.article_set.all()`获取作者所有文章。
17 1
|
1天前
|
安全 数据库 开发工具
Django实战:从零到一构建安全高效的Web应用
Django实战:从零到一构建安全高效的Web应用
64 0
|
1天前
|
存储 数据库 Python
Django教程第6章 | web开发实战-文件上传(导入文件、上传图片)
web应用实战:导入文件解析到DB,上传图片【2月更文挑战第25天】
59 0
Django教程第6章 | web开发实战-文件上传(导入文件、上传图片)
|
1天前
|
存储 前端开发 JavaScript
Django教程第4章 | Web开发实战-三种验证码实现
手动生成验证码,自动生成验证码,滑动验证码。【2月更文挑战第24天】
48 0
Django教程第4章 | Web开发实战-三种验证码实现
|
1天前
|
存储 中间件 数据安全/隐私保护
Django教程第3章 | Web开发实战-登录
登录案例、Djiango中间件【2月更文挑战第23天】
63 2
Django教程第3章 | Web开发实战-登录
|
1天前
|
JavaScript 关系型数据库 MySQL
Django教程第2章| Web开发实战-用户管理
基于Django实现用户管理:增删改查,搜索,分页。【2月更文挑战第22天】
63 0
Django教程第2章| Web开发实战-用户管理
http://www.vxiaotou.com