0 / 0 / 0
Регистрация: 13.03.2013
Сообщений: 18

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

14.07.2014, 14:48. Показов 1162. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru