Форум программистов, компьютерный форум, киберфорум
Python: Web
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 13.03.2013
Сообщений: 18

Последовательное выполнение запросов, без объединения в один общий

14.07.2014, 14:48. Показов 1155. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
К примеру есть такой код

Python
1
Publisher.objects.filter(book__rating__gt=3.0).annotate(num_books=Count('book'))

Проблема в том, что джанга иногда формирует запрос, противоречащий здравой логике. Например в данном примере будет сформирован такой запрос, при выполнении которого, у каждого автора в атрибуте num_books будет не общее количество его книг, а количество его книг с рейтингом > 3.0.
SQL
1
2
3
4
SELECT "app_publisher"."id", "app_publisher"."name", "app_publisher"."num_awards", COUNT("app_book"."id") AS "num_books" 
FROM "app_publisher" LEFT OUTER JOIN "app_book" ON ( "app_publisher"."id" = "app_book"."publisher_id" ) 
WHERE "app_book"."rating" > 3.0  
GROUP BY "app_publisher"."id", "app_publisher"."name", "app_publisher"."num_awards"
Этот пример взят из документации и там таких нюансов с последовательными вызовами фильтров, сортировок... полно.


Может как-то можно выполнить сначала запрос
Python
1
Publisher.objects.filter(book__rating__gt=3.0)
получить объект с результатами, а потом уже запрос
Python
1
.annotate(num_books=Count('book'))
который будет применён именно к объекту с этим результатом? Или же как-то указать джанге, чтобы формировала один запрос, вложенный в другой:
SQL
1
2
3
  SELECT ... 
  FROM  (SELECT ... FROM ... WHERE) 
  WHERE ...
Или же только один вариант - вручную писать на SQL языке запросы?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.07.2014, 14:48
Ответы с готовыми решениями:

Последовательное выполнение запросов
Доброго времени суток! Имеется действие, добавляющее комментарий в БД и вызываемое клиентами с помощью ajax запросов. Появилась...

Последовательное выполнение нескольких запросов
Добрый день! Товарищи, столкнулся с задачей, которую пока не могу сам решить - прошу помощи! Как сейчас я делаю: Изменяю...

Последовательное выполнение SQL запросов
Доброго времени суток. Дельфи 7 + ADO + Dbf, драйвер доступа VFPOLEDB строка подключения: Provider=VFPOLEDB.1;Data...

3
 Аватар для Wolkodav
842 / 480 / 58
Регистрация: 18.09.2012
Сообщений: 1,688
14.07.2014, 15:05
dovskr, можете sql подробнее написать?
0
0 / 0 / 0
Регистрация: 13.03.2013
Сообщений: 18
14.07.2014, 15:32  [ТС]
Wolkodav, вы про последний SQL код? Если да то там всё просто. Вложенный SELECT FROM WHERE
символизирует
Python
1
 .filter(book__rating__gt=3.0)
а внешний SELECT FROM WHERE символизирует
Python
1
.annotate(num_books=Count('book'))
0
 Аватар для Wolkodav
842 / 480 / 58
Регистрация: 18.09.2012
Сообщений: 1,688
14.07.2014, 15:54
dovskr, не, sql покажите который хотите.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.07.2014, 15:54
Помогаю со студенческими работами здесь

Последовательное выполнение ajax-запросов
У меня задача такая: в цикле перебирается набор элементов, и для каждого вызывается функция, выполняющая аякс-запрос, которая в свою...

Последовательное выполнение 3х SQL запросов
neobhodimo posledovatelno vipolnit 3 sql-query. kak predotvratit chastichnoe vipolnenie(toest 1 ili 2 query vipolnajutsa a ostatok net): ...

Последовательное выполнение ajax-запросов mysql
Имеется вот такой скрипт var i = 0; function next() { if (i < length) document.setTimeout('myfunc_1('+i+')', 100); i = i + 1; ...

Как реализовать последовательное выполнение паралельных запросов?
Как пример биржа обмена валют. Если 2 юзера одновременно добавят ордер, это может вызвать глюк если оба они работают с одними и теми же...

Получить один общий результат от нескольких последовательных get запросов
Добрый день! Очень надеюсь на помощь форумчан, т.к. с ангуляром практически не знакома, но требуют.. Есть функция, которая делает...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru