在Django框架中,子模型与主模型的关联通常是通过外键(ForeignKey)来实现的。外键是一种数据库约束,它允许一个模型(子模型)引用另一个模型(主模型)的主键。这种关联关系在Django中被称为一对多关系。
外键(ForeignKey):
OneToOneField
。ForeignKey
。ManyToManyField
。假设我们有两个模型:Author
和Book
,其中每个作者可以写多本书。
from django.db import models
class Author(models.Model):
name = models.CharField(max_length=100)
class Book(models.Model):
title = models.CharField(max_length=100)
author = models.ForeignKey(Author, on_delete=models.CASCADE)
在这个例子中,Book
模型通过author
字段与Author
模型关联起来。on_delete=models.CASCADE
表示如果一个作者被删除,那么所有与该作者关联的书籍也会被删除。
问题:如何查询某个作者的所有书籍?
解决方法:
author = Author.objects.get(id=1)
books = author.book_set.all() # 获取该作者的所有书籍
或者使用Django的反向关系查询:
books = Book.objects.filter(author_id=1) # 直接通过外键字段过滤
问题:如何添加一本书到某个作者?
解决方法:
author = Author.objects.get(id=1)
book = Book(title="New Book", author=author)
book.save()
或者使用Django的create
方法:
author.books.create(title="New Book")
通过这些方法,你可以轻松地管理和查询Django中的模型关联关系。
领取专属 10元无门槛券
手把手带您无忧上云