In this blog, we will discuss how to work with GROUP BY, WHERE, and HAVING clauses in SQL and explain the concept with an example in a simple way. I hope this is very useful for beginners and intermediates to help them understand the basic concept.
Group by clause
The Group by clause is often used to arrange identical duplicate data into groups with a select statement to group the result-set by one or more columns. This clause works with the select specific list of items, and we can use HAVING, and ORDER BY clauses. Group by clause always works with an aggregate function like MAX, MIN, SUM, AVG, COUNT.
Let us discuss group by clause with an example. We have a VehicleProduction table and there are some models with a price and it has some duplicate data. We want to categorize this data in a different group with a respective total price.
Example
Create table VehicleProduction
(
Id int primary key Identity,
Model varchar(50),
Price money
)
Insert into VehicleProduction values('L551', 850000),('L551', 850000),('L551', 850000),('L551', 750000),
('L538', 650000),('L538', 650000),('L538', 550000),('L530', 450000),('L530',350000), ('L545', 250000)
Select * from VehicleProduction
Output
data:image/s3,"s3://crabby-images/6e911/6e91172be95274e211af7801362b0177be46414c" alt=""
Aggregate Functions
MAX()- function returns the maximum value of the numeric column of specified criteria.
Example
Select max(Price) As 'MaximumCostOfModel' from VehicleProduction
Output
data:image/s3,"s3://crabby-images/ab2a0/ab2a0ba4d25f65c2af080e8039fb91c413bcd03c" alt=""
MIN()- function returns the minimum of the numeric column of specified criteria.
Example
Select Min(Price) As 'MinimumCostOfModel' from VehicleProduction
Output
data:image/s3,"s3://crabby-images/ffd6e/ffd6e54e330427ac9b41a8b733a46545dc23778b" alt=""
MIN()- function returns the minimum of the numeric column of specified criteria.
Example
Select Min(Price) As 'MinimumCostOfModel' from VehicleProduction
Output
data:image/s3,"s3://crabby-images/ffd6e/ffd6e54e330427ac9b41a8b733a46545dc23778b" alt=""
SUM()- function returns the total sum of a numeric column of specified criteria.
Example
Select SUM(Price) As 'SumCostOfAllModel' from VehicleProduction
Output
data:image/s3,"s3://crabby-images/df4fb/df4fb97d9dd1c4fb430ae12197f02ac76c449504" alt=""
AVG()- function returns the average value of a numeric column of specified criteria.
Example
Select AVG(Price) As 'AverageCostOfModel' from VehicleProduction
Output
data:image/s3,"s3://crabby-images/d2b94/d2b94e80f67ddd555defd6dcd3e70f0f6a728e1b" alt=""
COUNT()- function returns the number of rows that match specified criteria.
Example
Select Count(Price) As 'TotalVehicleModels' from VehicleProduction
Output
data:image/s3,"s3://crabby-images/52d36/52d36b59ee168cc5ac32c8336d4704a906eecf4f" alt=""
Distinct clause
The distinct clause is used to filter unique records out of the duplicate records that satisfy the query criteria.
Example
Select Distinct(Model), Price from VehicleProduction
Output
data:image/s3,"s3://crabby-images/acd38/acd388f8adb524d75f439101b54a3725a139bcbd" alt=""
Group by clause
The Group by clause is often used to arrange the identical duplicate data into groups with the select statement. This clause works with the select specific list of items, for that we can use HAVING, and ORDER BY clauses.
Syntax
SELECT Column1, Column2
FROM TableName
GROUP BY Column1, Column2
Example
Select * from VehicleProduction
Select Model, Price from VehicleProduction
group by Model, Price
Output
data:image/s3,"s3://crabby-images/c768a/c768acce885615da138defd1cb7aa847b16014a1" alt=""
Let’s look at an example of a GROUP BY with aggregate functions.
GROUP BY with aggregate functions
Example
Select Model, Price, Count(*) As QtyOfModel, Sum(Price) As TotPriceOfModel from VehicleProduction
group by Model, Price
Output
data:image/s3,"s3://crabby-images/a050d/a050dee240086a2149a52f0f8473caeb8cfe9885" alt=""
Where clause
Where clause works with select clause but won’t work on the group by or aggregate function condition.
Example 1
Select Model, Price from VehicleProduction
where Model != 'L530'
group by Model, Price
Output
data:image/s3,"s3://crabby-images/4b6bb/4b6bbd68c7da66c20da4e6a0b237e7fbcbade483" alt=""
Example 2
We can’t use where clause after group by clause
Select Model, Price from VehicleProduction
group by Model, Price
where Model != 'L530'
Output
data:image/s3,"s3://crabby-images/d50ef/d50ef11e4bb76ed83172f227d1e8fdd32b26ade2" alt=""
Having clause
Having clause works with a group by clause but specifically works on aggregate function condition.
Example
Select Model, Price from VehicleProduction
Group by Model, Price
Having SUM(Price) > 600000.00
Output
data:image/s3,"s3://crabby-images/e66a2/e66a2b78aed253afcee58292a6570c068642fe14" alt=""
ORDER BY clause
Order By clause shows the records in ascending or descending order of the specific condition.
Example
Select Model, Price from VehicleProduction
Group by Model, Price
Having SUM(Price) > 400000.00
order by Price desc
Output
data:image/s3,"s3://crabby-images/de03c/de03c51db9e639afb1f8bed670e1806fc34bd527" alt=""
I hope you understand the concept, please post your feedback, questions, or comments about this blog and feel free to tell me the required changes in this write-up to improve the content quality.
HostForLIFEASP.NET SQL Server 2019 Hosting
data:image/s3,"s3://crabby-images/e3f46/e3f46021db6e8e535b850af37d14f80c0ca38f2e" alt=""