DQL выбирает всех пользователей и подсчитывает количество бронирований каждого

Я пытаюсь выбрать всех своих пользователей и для каждого пользователя подсчитать количество сделанных и входящих бронирований. На данный момент у меня есть это

$qb = $this->createQueryBuilder('user');
return $qb->select('user')
  ->leftJoin('user.reservations', 'reservations')
  ->leftJoin('reservations.marketDate', 'market_date')
  ->addSelect('COUNT(nb_reservations FROM reservations WHERE market_date.date >= CURRENT_DATE())')
  ->orderBy('user.name')
  ->groupBy('user.id')
  ->getQuery()
  ->getResult();

Но у меня такая ошибка

[Semantical Error] line 0, col 59 near 'market_date >=': Error: Class 'market_date' is not defined.

Помогите, пожалуйста

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
66
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Синтаксис в СЧИТАТЬ кажется неправильным: COUNT не должен включать весь оператор. Попробуй это:

->addSelect('COUNT(nb_reservations) FROM reservations WHERE market_date.date >= CURRENT_DATE()')

Спасибо за ответ, я попробовал ваше решение, но теперь у меня ошибка [Semantical Error] line 0, col 41 near 'reservations': Error: Class 'reservations' is not defined.

Zahori 09.05.2018 12:42
Ответ принят как подходящий

Попробуй это:

$qb = $this->createQueryBuilder('user');
return $qb->select('user, count(reservations) as count')
  ->leftJoin('user.reservations', 'reservations')
  ->leftJoin('reservations.marketDate', 'market_date')
  ->where('market_date.date >= CURRENT_DATE()')
  ->orderBy('user.name')
  ->groupBy('user.id')
  ->getQuery()
  ->getResult();

это решение выбирает пользователей, у которых есть будущие бронирования, и подсчитывает будущие бронирования пользователя. Я хотел бы выбрать всех пользователей и подсчитать количество будущих бронирований, даже если их 0

Zahori 09.05.2018 14:03

Тогда вам нужно вместо этого использовать левое внешнее соединение.

Vyctorya 09.05.2018 14:11

Другие вопросы по теме