D
Diregent18. Januar 2021 05:53

Не получается prefetch_related на M2M полях

Приветствую! работаю над волонтерским проектом, изучаю django. Очень понравилась тема про оптимизацию запросов к БД и вообще весь сайт!
Но у меня в model- ManyToManyField через through модель, где 2 ForeignKey- все как обычно. На stackoverflow есть вопросы об этом, из которых вроде следует, что надо делать prefetch_related(Prefetch("поле м2м"), ThroughModel..select_related("поле foreign key"), но QuerySet.query показывает, что никакого join не происходит:( пробовал и поля указывать через model__field- тоже самое...

А еще пагинация... Изначальный запрос даже если и за-join-ится, то вернет ~50 тыщ рядов. Я хотел взять QuerySet после панинации для 1 page, на нем сделать select/prefetch related- может так меньше рядов потянет? я даже от отчаяния уже начал конвертить queryset в свои классы, в которые сам сделаю запросы в БД, как нужно, но это совсем не стандартно, и в Paginator такой класс не подсунуть.

Вот такая печаль... Можно код показать?

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

3
Илья Чичак
  • 18. Januar 2021 07:01
  • Die Antwort wurde als Lösung markiert.

join случается, если делать select_related

префетч делается в два запроса - сначала изначальный запрос, а потом связанные с ним объекты. мерж этих запросов происходит в рантайме

можно почитать тут: https://medium.com/better-programming/django-select-related-and-prefetch-related-f23043fd635d

    D
    • 23. Januar 2021 07:17

    Благодарю Вас, Илья. Долго разбирался, стало понятно!
    Там самое сложное, что дальнейшие query не может быть filter или get- тогда prefetch не срабатывает. Сейчас пока я все сделал на select_related и своем cache.

      Илья Чичак
      • 23. Januar 2021 12:25

      это да. и правильнее всего было бы сделать все фильтрации и только в самом конце вызвать prefetch_related

      например, если все это уходит в шаблон, я бы поступил следующим образом:

      def some_view(request, *args, **kwargs):
          qs = SomeModel.objects.filter(...)
          if ...:
              qs = qs.filter(...)
          else:
              qs = qs.filter(...)
          qs = qs.exclude(...)
          return render(request, 'template.html', {'objects': qs.prefetch_related()}
      

        Kommentare

        Nur autorisierte Benutzer können Kommentare posten.
        Bitte Anmelden oder Registrieren
        Letzte Kommentare
        A
        ALO1ZE19. Oktober 2024 08:19
        Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
        ИМ
        Игорь Максимов5. Oktober 2024 07:51
        Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
        d
        dblas55. Juli 2024 11:02
        QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
        k
        kmssr8. Februar 2024 18:43
        Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
        Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
        Jetzt im Forum diskutieren
        J
        JacobFib17. Oktober 2024 03:27
        добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
        JW
        Jhon Wick1. Oktober 2024 15:52
        Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
        КГ
        Кирилл Гусарев27. September 2024 09:09
        Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
        F
        Fynjy22. Juli 2024 04:15
        при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

        Folgen Sie uns in sozialen Netzwerken