Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Django 已使用不同的查询集查看查找_Django_Caching_Django Views - Fatal编程技术网

Django 已使用不同的查询集查看查找

Django 已使用不同的查询集查看查找,django,caching,django-views,Django,Caching,Django Views,我按照ajax请求对信用卡列表进行排序。第一次一切顺利时,我会得到信用卡的排序列表,并更新缓存。但是当我再次尝试排序时,我得到了一个错误 “creditpayments”查找已与其他查询集一起出现。您可能需要调整查找的顺序 如果不更新缓存,则不会出现错误。但我需要更新它 型号 class Credit(models.Model): pass class CreditPayment(models.Model): credit = models.ForeignKey(Credit

我按照ajax请求对信用卡列表进行排序。第一次一切顺利时,我会得到信用卡的排序列表,并更新缓存。但是当我再次尝试排序时,我得到了一个错误

“creditpayments”查找已与其他查询集一起出现。您可能需要调整查找的顺序

如果不更新缓存,则不会出现错误。但我需要更新它

型号

class Credit(models.Model):
    pass


class CreditPayment(models.Model):
    credit = models.ForeignKey(Credit, on_delete=models.CASCADE, related_name='creditpayments')
    rate = models.DecimalField(_('rate'), max_digits=7, decimal_places=2)
class SortedCreditsList(ListView):
    def get(self, *args, **kwargs):
        if self.request.is_ajax():
            credits = cache.get('credits')
            prefetch = Prefetch('creditpayments', CreditPayment.objects.all())
            credits = credits.prefetch_related(prefetch).annotate(min_rate=Min('creditpayments__rate'))
            credits = credits.order_by('min_rate')
            cache.set('credits', credits)
            credits = credits.filter(best=False, hot=False)

            template_ajax = render_to_string(
                    template_name='credits/includes/credits_filter_result.html',
                    context={
                        'credits': credits,
                    })

            return JsonResponse({'success': True, 'template': template_ajax})
视图

class Credit(models.Model):
    pass


class CreditPayment(models.Model):
    credit = models.ForeignKey(Credit, on_delete=models.CASCADE, related_name='creditpayments')
    rate = models.DecimalField(_('rate'), max_digits=7, decimal_places=2)
class SortedCreditsList(ListView):
    def get(self, *args, **kwargs):
        if self.request.is_ajax():
            credits = cache.get('credits')
            prefetch = Prefetch('creditpayments', CreditPayment.objects.all())
            credits = credits.prefetch_related(prefetch).annotate(min_rate=Min('creditpayments__rate'))
            credits = credits.order_by('min_rate')
            cache.set('credits', credits)
            credits = credits.filter(best=False, hot=False)

            template_ajax = render_to_string(
                    template_name='credits/includes/credits_filter_result.html',
                    context={
                        'credits': credits,
                    })

            return JsonResponse({'success': True, 'template': template_ajax})
回溯

ValueError at /sorted_kredit/
'creditpayments' lookup was already seen with a different queryset. You may need to adjust the ordering of your lookups.

Traceback:  

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/core/handlers/base.py" in get_response
  149.                     response = self.process_exception_by_middleware(e, request)

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/core/handlers/base.py" in get_response
  147.                     response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/views/generic/base.py" in view
  68.             return self.dispatch(request, *args, **kwargs)

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/views/generic/base.py" in dispatch
  88.         return handler(request, *args, **kwargs)

File "/home/m0nte-cr1st0/work_projects/startup/finbee/credits/views.py" in get
  555.             cache.set('credits', credits)

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/core/cache/backends/locmem.py" in set
  75.         pickled = pickle.dumps(value, pickle.HIGHEST_PROTOCOL)

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/db/models/query.py" in __getstate__
  211.         self._fetch_all()

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/db/models/query.py" in _fetch_all
  1076.             self._prefetch_related_objects()

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/db/models/query.py" in _prefetch_related_objects
  656.         prefetch_related_objects(self._result_cache, self._prefetch_related_lookups)

File "/home/m0nte-cr1st0/.virtualenvs/finbee/local/lib/python2.7/site-packages/django/db/models/query.py" in prefetch_related_objects
  1397.                                  "You may need to adjust the ordering of your lookups." % lookup.prefetch_to)

已预取的预取模型导致的错误

当您从缓存中获取
积分
值时,对象已预取

如果hasattr(缓存,'credits'):#已缓存
credits=cache.get('credits')
其他:
预回迁=预回迁('creditpayments',CreditPayment.objects.all())
信用=信用。预回迁相关(预回迁)。注释(最低利率=最低(“信用付款利率”))
信用=信用。订购人(“最低费率”)
cache.set('credits',credits)
我认为这段代码可以让你的代码正常工作