170 похожих чатов

Всем привет, делаю табличку с данными. Вкратце есть Модель Сигнал(свои

поля), Открытие(относится к Сигнал по pk), Закрытие(аналогично).
Сейчас 850 Сигналов, в шаблон передаю в views Signal.objects.all().order_by('created_at')
Внутри шаблона достаю Открытие и Закрытие в цикле: написал для Сигнал метод Open.objects.filter(signal_id=pk) и снова таки циклом по ним вывожу их в шаблоне. И вся эта история какая-то медленная получается.

Может я что не так делаю? Как это все ускорить? Какие практики лучшие для подобного?
Спасибо, Буду благодарен за любую наводку.

4 ответов

6 просмотров

Ну для похожей схемы можно использовать OneToOne, правда тут с количеством запросов проблемы особо не решить. А что именно выводится из этих Открытие/Закрытие? Если по несколько полей, то может вынести их в Сигнал? в моделях Открытие/Закрытие убрать foreignkey class Сигнал(models.Model): ... текущие поля openinig = models.OneToOne(Открытие) closing = models.OneToOne(Закрытие) И тогда одним запросом все данные можно подтянуть Сигнал.objects.select_related('opening', 'closing')

Andrey- Автор вопроса

Сейчас попробую, спасибо

Andrey- Автор вопроса

а нет, у меня там onetomany

На один Сигнал может быть более 1-го Открытия/Закрытия?

Похожие вопросы

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
Открыл свой двухкилобайтный экзешник в x32dbg, а тут какая-то хрень. Смущает кнопка "выполнить до пользовательского кода", а что ещё может быть в файле помимо него ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
11
Вопрос тем кто смотрит видео и слушает подкасты - как вы потом ищете нужную вам информацию? Вот статью я прочитал, потом могу искать нужную мне часть банальным поиском. Пропус...
Aleksandr Druzhinin
4
Мне были интересны дишные хаки и я нашёл любопытный способ на форуме через __traits, что-то вроде int delegate(int) fac = (int n) => n == 0 ? 1 : n * __traits(parent, {})(n - ...
Constantin F.
1
Всем привет, подскажите/посоветуйте пожалуйста. Фаердак компоненты, имею одно место где бизнес хочет видеть при открытии формы список всех клиентов, это порядка 30к. Мои дово...
Sasha Sch
14
Ребят, если кто в курсе - скажите, а в загранке такое же засилье маркетплейсов? или там простые сермяжные интернет-магазины живут попроще?
Андрей [aharito] Харитонов
14
@FAssembler ты много с формами работал, как цикл обработки сообщений от окошек надо делать, чтобы IsDialogMessage не ломал ввод в эдиты и навигация по табам работала?
The Bird of Hermes
8
Карта сайта