美好的一天,不久前,与Django合作。 遇到以下问题。
有两种型号
class Product(models.Model):
productID = models.AutoField(primary_key=True)
brandID = models.ForeignKey(Brand, verbose_name=u'Бренд')
categoryID = models.ForeignKey(Category, verbose_name=u'Категория')
productPhotos = models.ManyToManyField("ProductPhoto", verbose_name = "Фотографии товара", related_name="photos", blank=True)
class ProductPhoto(models.Model):
productPhotoID = models.AutoField(primary_key=True)
productID = models.ForeignKey(Product)
imageFile = models.FileField(u'Путь к изображение', upload_to=makeUploadPath)
dateModified = models.DateField(auto_now=True)
对于管理员,请使用以下TabularInline
class ProductPhotoInline(admin.TabularInline):
model = ProductPhoto
verbose_name = u"Фото"
verbose_name_plural = u"Фотографии"
class ProductAdmin(admin.ModelAdmin):
list_display = ('title')
search_fields = ...
fieldsets = ...
)
inlines = [ ProductPhotoInline, ]
在表ProdcutPhoto productId字段中添加产品时出现的问题已填充,表Products productPhotos中的字段为空。如何最好地填补这两个领域。
答案 0 :(得分:0)
你应该删除productPhotos ManyToMany字段,它是多余的。如果每张照片只附加到一个产品上,那么就可以使用productID ForeignKey。
要从产品实例访问照片,您可以使用productphoto_set
,例如
product = Product.objects.get(pk=1)
photos = product.productphoto_set.all()