Что является наиболее оптимизированным способом использования аннотата с функцией подсчета со многими фильтром в Django Python

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Что является наиболее оптимизированным способом использования аннотата с функцией подсчета со многими фильтром в Django

Сообщение Anonymous »

Например, в школе есть много данных для хранения примера «класс», «Студент», «Книга» и т. Д. Кроме того, модель использовалась SoftDelete (Softlelete относится к действию при удалении просто изменить IS_DELETED на True в модели). В каждой модели есть Create_time , update_time , is_delete и т. Д. В моем коде теперь я использую метод ниже, он потратил не менее 30 лет на запуск SQL.
Так что является наиболее оптимизированным способом запроса count с помощью фильтра, который содержит многие условия? Также иногда нам нужно считать одну и ту же модель, но используя различный фильтр < /p>
Вот пример кода в Django (проверьте данные подсчета для каждой школы). < /P>

Код: Выделить всё

# In this code, each model already implements softdelete manager query.
School.objects.annotate(
number_of_class=Count(
"class", filter=Q(class__is_deleted=False, class__create_time__lte=datetime, ...more filter), distinct=True
),
number_of_student=Count(
"student", filter=Q(student__is_deleted=False, student__create_time__lte=datetime, ...more filter), distinct=True
),
number_of_public_book=Count(
"book", filter=Q(book__is_deleted=False, book__create_time__lte=datetime, book__create_time__gte=datetime, book__type=1, ...more filter), distinct=True
),
number_of_private_book=Count(
"book", filter=Q(book__is_deleted=False, book__create_time__lte=datetime, book__create_time__gte=datetime, book__type__in=[2,3], ...more filter), distinct=True
)
more_count...
)
Пожалуйста, помогите дать все запросы кода, которые, как вы знаете, и то, что, по вашему мнению, можно оптимизировать для подсчета многих пунктов и фильтров.>

Подробнее здесь: https://stackoverflow.com/questions/781 ... -many-filt
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»