问题:在mysql中查询数据时,代码如下:

1 skus = category.sku_set.filter(is_launched=True).order_by(sort_field)

skus 取不到数据,提示 skus: Unable to get repr for <class 'django.db.models.query.QuerySet'>

 

解决:

多方查找,是因为,原模型类中的

1 default_image_url = models.CharField(max_length=200, default='', null=True, blank=True, verbose_name='默认图片')

迁移到数据库中变成了default_image,此时如果把模型类中的default_image_url改成default_image,还会报错 'str' object has no attribute 'url'

 

最终改成

1 default_image = models.ImageField(max_length=200, default='', null=True, blank=True, verbose_name='默认图片')

解决问题!

 

总结:

1 目前所知只有模型类中的外键字段,mysql里会加上 _id,其余字段都是一一对应,不会改变的

2 ImageField 是用于保存图像文件的字段,有url这个属性,而CharField 没有url 这个属性

3 网上遇到这个问题的人很多,大部分解决办法有两个方向

  1)因为__str__方法返回的有日期,需要转成str

  2)迁移模型类出错,我遇到的错误属于这个范畴