Django中select_related 的作用

Django中这句代码Dynamic.objects.select_related('song')是什么意思?

在 Django 中,这句代码:

复制代码
Dynamic.objects.select_related('song')

的作用是 在查询 Dynamic 模型的同时,预加载 song 关联的外键对象,从而减少数据库查询次数,提高查询效率。


select_related() 适用于 外键(ForeignKey)或一对一(OneToOneField) 的预加载,Django 会使用 SQL 的 JOIN 语句 一次性获取相关数据,避免 N+1 查询问题。


2. 假设的模型结构

假设 Dynamic 模型中有一个 song 字段,它是指向 Song 模型的 外键

复制代码
class Song(models.Model):
    title = models.CharField(max_length=100)
    artist = models.CharField(max_length=100)

class Dynamic(models.Model):
    song = models.ForeignKey(Song, on_delete=models.CASCADE)
    views = models.IntegerField()

如果你直接查询:

复制代码
dynamics = Dynamic.objects.all()
for dynamic in dynamics:
    print(dynamic.song.title)  # 这里会触发 N+1 查询问题

Django 默认是 懒加载 ,每次访问 dynamic.song 时,都会执行一个新的 SQL 查询(N+1 查询问题)。


3. select_related('song') 的优化

复制代码
dynamics = Dynamic.objects.select_related('song')
for dynamic in dynamics:
    print(dynamic.song.title)  # 不会触发额外查询

Django 会使用 JOIN 语句 一次性获取 DynamicSong 表的数据:

复制代码
SELECT dynamic.*, song.*
FROM dynamic
JOIN song ON dynamic.song_id = song.id;

这样,所有数据都在 一次查询 中获取,避免了多个查询,提高了性能。


  • select_related('song') 适用于 外键(ForeignKey)和一对一(OneToOneField) ,使用 JOIN 查询 直接获取数据。
  • prefetch_related('song') 适用于 多对多(ManyToManyField)或反向外键(related_name) ,会执行 两次查询,然后在 Python 代码中进行匹配。

如果 song 是外键,推荐使用 select_related('song'),因为它更高效。

相关推荐
就叫飞六吧29 分钟前
MySQL不停机迁移完全指南
数据库·mysql
猎人everest1 小时前
Windows系统Redis(8.2.2)安装与配置完整教程
数据库·windows·redis
苦学编程的谢1 小时前
Redis_10_Zset
数据库·redis·缓存
q***42051 小时前
在Spring Boot项目中使用MySQL数据库
数据库·spring boot·mysql
故林丶2 小时前
【Django】Django笔记
python·django
我系真滴菜2 小时前
SQLiteStudio基本操作教程
数据库
她说彩礼65万2 小时前
C# Sqlite帮助类
jvm·sqlite·c#
q***49862 小时前
在Django中安装、配置、使用CKEditor5,并将CKEditor5录入的文章展现出来,实现一个简单博客网站的功能
数据库·django·sqlite
q***18062 小时前
如何使用C#与SQL Server数据库进行交互
数据库·c#·交互
Wang's Blog2 小时前
MySQL: 操作系统对MySQL性能的影响及选型指南
数据库·mysql