我有两个 Django 模型:
class Product(models.Model):
name = models.CharField(max_length=80, null=True)
is_active = models.BooleanField(default=False, null=False)
class Image(models.Model):
url = models.CharField(max_length=255, unique=True, null=False)
product = models.ForeignKey('Product', related_name='images')
我有一组特定的产品。每个产品都有多个图像。初始调用类似于:
product_list = product_list.filter(is_active=True).prefetch_related('images')
product_list 然后根据应用的过滤器被削减。
当我尝试在显示层(模板)中使用 product_list 时,我会迭代产品列表。我可以访问除图像之外的所有产品字段。
{{ product.images.0.id }} ==> 空
{{ product.images }} ==> 返回 Image.None
通过调试器运行代码,我可以看到正在执行的 Image SQL 查询,只是没有任何数据传递给模板。那里肯定有数据,因为我可以验证通过我的 SQL 客户端运行它的查询。有谁知道为什么会这样?如何访问给定产品的图像?
最佳答案
我解决了我的问题。预取数据必须像这样访问:product.images.all.0.id
关于Django prefetch_related 无法将数据传递给模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34831511/