如何在 Django 模型 ForeignKey 和 OneToOneField 中获取所有相关对象

How to get all related objects in django model ForeignKey and OneToOneField

我正在使用 Django 1.9。 我有以下 Django 模型:

@python_2_unicode_compatible
class Projects(models.Model):
    index = models.IntegerField(blank=True,default=1)
    year = models.CharField(max_length=255, blank=True)
    title = models.CharField(max_length=255, blank=True)
    description = models.TextField(blank=True)

    def __str__(self):
        return  '%s, %s, %s, %s' %(self.index,self.year,self.title,
               self.description)
@python_2_unicode_compatible
class Awards(models.Model):
    title = models.CharField(max_length=255, blank=True)

    def __str__(self):
        return '%s' %( self.title)


@python_2_unicode_compatible
class Images(models.Model):
    projects = models.ForeignKey(Projects,null=True,blank=True, related_name='images_projects')
    awards =  models.OneToOneField(Awards,null=True,blank=True,related_name='images_awards')
    title = models.CharField(max_length=255, blank=True)
    file = models.ImageField(upload_to='upload_images/')
    uploaded_at = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return '%s, %s' %(self.file, self.pk)

1)我正在尝试获取与模型项目相关的所有模型对象项目和模型对象图像Projects.objects.all().select_related('images_projects') 结果,我只得到模型对象 Projects。

2) 我想获取Images中模型Awards和关联字段的所有对象。

 Awards.objects.all().prefetch_related('images_awards')

因此,我只收到了 Award 模型的所有字段。

如何在我的2个案例中将相关字段与主模型的所有对象一起获取?

select_related and prefetch_related 性能提升器 ,可以检索 当前查找 的相关对象。查询 returns 对应的对象(主要)用于查找,然后相关的对象被一起获取;

您仍然需要使用常规语法来访问 Python 中的相关对象。

例如

for p in Projects.objects.all().select_related('images_projects'):
    print(p.images_projects)

不会为访问 p.images_projects 进行数据库访问,因为它已经与 project.

一起获取了