Присоединитесь к двум таблицам с определенными условиями в mysql

у меня два стола

Таблица 1: (пользователь) идентификатор, имя, имя пользователя, пароль

Таблица 2: (заказ) идентификатор, пользователь, статус

положение делстолбец имеют два значения: 1 (отмена заказа) или 2 (успешный заказ)

Я хочу показать список все пользователи с количеством заказов как заказы (количество заказов только для успешного заказа)

Я пишу этот sql:

  select `user`.* , count(`sale`.`user`) as 'orders'
  from `user` 
  left join `sale`
      on `sale`.`user` = `user`.`id`
  where `user`.`type` = 'customer'
    and (`sale`.`status` IS NULL OR `sale`.`status` = 2)
  group by `user`.`id`
  order by `user`.`id` DESC 

в этом запросе, если у пользователя нет никакого заказа или есть успешный заказ, отображается результат

но если пользователь отменил заказ, результат не отображается

Я хочу показать все пользователи в результате с столбцом заказов

Если статус заказа равен 2, в столбце заказа отображается количество успешных заказов.

Если статус заказа равен 1 или null (у пользователя нет заказа), в столбце результатов заказа отображается 0 счетчиков.

заранее спасибо

Некоторые примеры данных таблицы и ожидаемый результат были бы великолепны! (В виде форматированного текста, без изображений.) stackoverflow.com/help/репрекс

jarlh 22.05.2019 16:45
3 метода стилизации элементов HTML
3 метода стилизации элементов HTML
Когда дело доходит до применения какого-либо стиля к нашему HTML, существует три подхода: встроенный, внутренний и внешний. Предпочтительным обычно...
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
0
1
55
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Переместите условие на status в предложение on:

  select u.* , count(s.user) as orders
  from `user` u left join
       sale s
        on s.`user` = u.id AND s.status = 2
  where u.`type` = 'customer'
  group by u.id  -- ok, assuming id is unique
  order by u.id  DESC 

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