当我在新数据库上尝试不进行make迁移时,出现此错误:
django.db.utils.ProgrammingError:(1146,“表'dorogi_test.activities_category'不存在”))
它由以下查询引发:
models.Category.objects.filter(level=0, active=True).get_descendants(include_self=True)
哪个在迁移之前就退出,所以它不能存在不存在的表。
我尝试执行以下操作:
def get_top_news_category():
if models.Category.objects.exists():
return models.Category.objects.filter(level=0, active=True).get_descendants(include_self=True)
@permission_classes((permissions.AllowAny,))
class TopNewsViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
serializer_class = ArticleSerializer
c = get_top_news_category()
queryset = models.Article.objects.filter(hot=True, category__in=c).order_by('-id')[:3]
但是我的代码在此检查时也崩溃了。如何避免此错误,并让Django在不注释代码的情况下开始迁移?
哦。那很简单。只需将所有内容包装到函数中:
@permission_classes((permissions.AllowAny,))
class TopNewsViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
serializer_class = ArticleSerializer
def get_queryset(self):
c = models.Category.objects.filter(level=0, active=True).get_descendants(include_self=True)
return models.Article.objects.filter(hot=True, category__in=c).order_by('-id')[:3]
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句