djnago orm 一对多关系使用

在 Django 中,一对多关系通常通过外键(ForeignKey)来实现。以下是一个完整的示例,展示如何定义模型、创建一对多关系,并使用 Django ORM 进行连表查询。

1. 定义模型

假设我们有两个模型:AuthorBook一个作者可以有多本书,这就是一对多的关系

models.py
python 复制代码
from django.db import models

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

    def __str__(self):
        return self.name

class Book(models.Model):
    title = models.CharField(max_length=200)
    publication_date = models.DateField()
    author = models.ForeignKey(Author, related_name='books', on_delete=models.CASCADE)

    def __str__(self):
        return self.title

2. 创建和应用迁移

在定义好模型后,需要创建和应用数据库迁移。

bash 复制代码
python manage.py makemigrations
python manage.py migrate

3. 创建一些示例数据

你可以使用 Django 管理后台或 Django shell 来创建一些示例数据。

使用 Django shell
bash 复制代码
python manage.py shell
python 复制代码
from myapp.models import Author, Book

# 创建作者
author1 = Author.objects.create(name="Author One", email="author1@example.com")
author2 = Author.objects.create(name="Author Two", email="author2@example.com")

# 创建书籍
Book.objects.create(title="Book One", publication_date="2023-01-01", author=author1)
Book.objects.create(title="Book Two", publication_date="2023-02-01", author=author1)
Book.objects.create(title="Book Three", publication_date="2023-03-01", author=author2)

4. 连表查询

现在可以使用 Django ORM 进行连表查询。

views.py
python 复制代码
from django.shortcuts import render
from myapp.models import Author, Book

def author_books(request, author_id):
    # 获取指定作者
    author = Author.objects.get(id=author_id)
    
    # 获取该作者的所有书籍
    books = author.books.all()
    
    return render(request, 'author_books.html', {'author': author, 'books': books})
urls.py
python 复制代码
from django.urls import path
from myapp import views

urlpatterns = [
    path('author/<int:author_id>/', views.author_books, name='author_books'),
]
author_books.html
html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>Author Books</title>
</head>
<body>
    <h1>Books by {{ author.name }}</h1>
    <ul>
        {% for book in books %}
            <li>{{ book.title }} ({{ book.publication_date }})</li>
        {% endfor %}
    </ul>
</body>
</html>

5. 复杂查询示例

如果需要进行更复杂的查询,比如获取所有书籍及其对应的作者,可以使用 select_relatedprefetch_related

python 复制代码
def all_books(request):
    # 获取所有书籍及其对应的作者
    books = Book.objects.select_related('author').all()
    
    return render(request, 'all_books.html', {'books': books})
all_books.html
html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>All Books</title>
</head>
<body>
    <h1>All Books</h1>
    <ul>
        {% for book in books %}
            <li>{{ book.title }} by {{ book.author.name }} ({{ book.publication_date }})</li>
        {% endfor %}
    </ul>
</body>
</html>

6. 更新 urls.py

python 复制代码
urlpatterns = [
    path('author/<int:author_id>/', views.author_books, name='author_books'),
    path('books/', views.all_books, name='all_books'),
]
相关推荐
gb42152875 小时前
java中将租户ID包装为JSQLParser的StringValue表达式对象,JSQLParser指的是?
java·开发语言·python
THMAIL5 小时前
量化股票从贫穷到财务自由之路 - 零基础搭建Python量化环境:Anaconda、Jupyter实战指南
linux·人工智能·python·深度学习·机器学习·金融
~-~%%5 小时前
从PyTorch到ONNX:模型部署性能提升
人工智能·pytorch·python
蒋星熠5 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
爬虫程序猿6 小时前
《京东商品详情爬取实战指南》
爬虫·python
胡耀超6 小时前
4、Python面向对象编程与模块化设计
开发语言·python·ai·大模型·conda·anaconda
大佬,救命!!!7 小时前
整理python快速构建数据可视化前端的Dash库
python·信息可视化·学习笔记·dash·记录成长
孔丘闻言7 小时前
python调用mysql
android·python·mysql
Teletele-Lin8 小时前
Miniconda安装与VSCode搭建远程Python、Jupyter开发环境
vscode·python·jupyter·环境配置·远程开发
伊玛目的门徒8 小时前
告别 OpenAI SDK:如何使用 Python requests 库调用大模型 API(例如百度的ernie-4.5-turbo)
python·openai·requests·大模型调用·ernie-4.5-turbo