Оператор выбора MySQL создать столбец, затем сравнить

Очень новичок в SQL. Попытка показать результаты только тогда, когда TotalSales меньше цели.

SELECT SUM(Table1.Column1) AS TotalSales
FROM Table 1
WHERE Table1.Goal > TotalSales
GROUP BY EmployeeID;

Это дает мне ошибку 1054: Неизвестный столбец.

Опять же, очень простой, но я застрял. Спасибо еще раз за помощь.

Для меня это звучит как ненормированная таблица. Судя по вашему запросу, я предполагаю, что у каждого продавца должна быть одна цель. Тем не менее, похоже, что в каждой строке таблицы есть экземпляр цели, который явно отслеживает активность продавцов. Рассмотрите возможность пересмотра дизайна вашей базы данных.

sticky bit 06.06.2018 15:03
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
1
36
1

Ответы 1

Вам нужен subquery с JOIN:

SELECT t1.*, t2.TotalSales
FROM TABLE1 t1 INNER JOIN (
       SELECT EmployeeID, SUM(Table1.Column1) AS TotalSales
       FROM Table1
       GROUP BY EmployeeID ) t2
ON t1.EmployeeID = t2.EmployeeID 
WHERE t1.Goal > t2.TotalSales;

Отлично, но вы не могли знать этого из предоставленной информации.

Strawberry 06.06.2018 15:07

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