Django关联关系之多对多关联

在Django框架中,多对多(ManyToMany)关联允许一个模型的实例与另一个模型的多个实例相关联,并且这种关系是相互的。即,一个实例可以关联到另一个模型的多个实例,同时,另一个模型的实例也可以反过来关联到第一个模型的多个实例。

Django通过ManyToManyField来实现多对多关联。下面是一个简单的例子,展示了如何在Django模型中定义和使用多对多关联。

假设我们有两个模型:Book(书籍)和Author(作者)。一本书可以由多个作者共同撰写,同时一个作者也可以撰写多本书。这就是一个典型的多对多关系。

python 复制代码
from django.db import models

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

    def __str__(self):
        return self.name

class Book(models.Model):
    title = models.CharField(max_length=200)
    authors = models.ManyToManyField(Author, related_name='books')

    def __str__(self):
        return self.title

在这个例子中,Book模型中的authors字段是一个ManyToManyField,它建立了BookAuthor之间的多对多关系。related_name='books'参数是一个可选的,它定义了从Author模型反向查询到Book模型时的名称。

如何使用多对多关联

  1. 添加关联

要为一本书添加作者,你可以使用add()方法。例如:

python 复制代码
# 假设已经有一些Author实例和Book实例
author1 = Author.objects.get(name='Author Name 1')
author2 = Author.objects.get(name='Author Name 2')
book = Book.objects.get(title='Book Title')

# 为这本书添加作者
book.authors.add(author1, author2)
  1. 查询关联

要查询一本书的所有作者,你可以直接访问authors字段,它会返回一个QuerySet,包含与该书相关联的所有Author实例。

python 复制代码
# 获取一本书的所有作者
authors = book.authors.all()
for author in authors:
    print(author.name)

同样地,要查询一个作者的所有书籍,你可以使用related_name参数指定的名称(在这个例子中是books

python 复制代码
# 获取一个作者的所有书籍
books = author1.books.all()
for book in books:
    print(book.title)
  1. 移除关联

要从一本书中移除作者,你可以使用remove()方法。

复制代码

python复制代码

|---|--------------------------------|
| | # 从这本书中移除一个作者 |
| | book.authors.remove(author1) |

  1. 清空关联

要移除一本书的所有作者,你可以使用clear()方法。

复制代码

python复制代码

|---|------------------------|
| | # 清空这本书的所有作者 |
| | book.authors.clear() |

  1. 设置关联

要设置一本书的作者(替换掉当前的作者列表),你可以使用set()方法。注意,如果传递的是一个不包含当前某些作者的列表,那么这些作者与该书之间的关联将被移除

python复制代码

|---|-------------------------------|
| | # 设置这本书的作者列表(替换当前列表) |
| | book.authors.set([author2]) |

通过这些方法,你可以轻松地在Django模型中管理和查询多对多关联。

相关推荐
IT_陈寒10 小时前
Python开发者必知的5大性能陷阱:90%的人都踩过的坑!
前端·人工智能·后端
流浪克拉玛依11 小时前
Go Web 服务限流器实战:从原理到压测验证 --使用 Gin 框架 + Uber Ratelimit / 官方限流器,并通过 Vegeta 进行性能剖析
后端
Flittly11 小时前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(3)TodoWrite (待办写入)
python·agent
孟沐11 小时前
保姆级教程:手写三层架构 vs MyBatis-Plus
后端
星浩AI11 小时前
让模型自己写 Skills——从素材到自动生成工作流
人工智能·后端·agent
华仔啊13 小时前
为啥不用 MP 的 saveOrUpdateBatch?MySQL 一条 SQL 批量增改才是最优解
java·后端
武子康14 小时前
大数据-242 离线数仓 - DataX 实战:MySQL 全量/增量导入 HDFS + Hive 分区(离线数仓 ODS
大数据·后端·apache hive
砍材农夫15 小时前
TCP和UDP区别
后端
千寻girling15 小时前
一份不可多得的 《 Django 》 零基础入门教程
后端·python·面试
千寻girling15 小时前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法