Professional Documents
Culture Documents
SQL - 4 Group Functions
SQL - 4 Group Functions
Aggregating Data
Using Group Functions
Asif Sohail
University of the Punjab
Punjab University College of Information Technology (PUCIT)
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 1
What Are Group Functions?
• Group functions operate on sets of rows to give one
result per group.
EMP
DEPTNO SAL
--------- ---------
10 2450
10 5000
10 1300
20 800
20 1100
20 3000 “maximum MAX(SAL)
20 3000 salary in ---------
20 2975 the EMP table” 5000
30 1600
30 2850
30 1250
30 950
30 1500
30 1250
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 2
Types of Group Functions
– MAX
– MIN
– SUM
– AVG
– COUNT
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 3
Using Group Functions
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 4
Using MIN and MAX Functions
MIN(HIRED MAX(HIRED
--------- ---------
17-DEC-80 12-JAN-83
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 5
Using AVG and SUM Functions
• You can use AVG and SUM for numeric data.
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 6
Using the COUNT Function
• COUNT(*) returns the number of rows in a table
satisfying a given condition (if any).
SQL> SELECT COUNT(*)
2 FROM emp
3 WHERE deptno = 30;
COUNT(*)
---------
6
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 7
Using the COUNT Function
COUNT(COMM)
-----------
4
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 8
Using the COUNT Function
• COUNT(DISTINCT expr) returns the number
of distinct non-null values of the expr.
COUNT(DISTINCT deptno)
----------------------
4
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 9
Group Functions and Null Values
• Group functions ignore null values in the
column.
AVG(COMM)
---------
550
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 10
Using the NVL Function
with Group Functions
AVG(NVL(COMM,0))
----------------
157.14286
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 11
Creating Groups of Data
EMP
DEPTNO SAL
--------- ---------
10 2450
10 5000 2916.6667
10 1300
20 800 “average DEPTNO AVG(SAL)
20 1100 salary
------- ---------
20 3000 2175 in EMP
20 3000 table 10 2916.6667
20 2975 for each 20 2175
30 1600 department” 30 1566.6667
30 2850
30 1250 1566.6667
30 950
30 1500
30 1250
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 12
Creating Groups of Data:
GROUP BY Clause
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 13
Using the GROUP BY Clause
• All columns in the SELECT list that are not in group
functions must be in the GROUP BY clause.
DEPTNO AVG(SAL)
--------- ---------
10 2916.6667
20 2175
30 1566.6667
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 14
Using the GROUP BY Clause
• The GROUP BY column does not have to
be in the SELECT list.
AVG(SAL)
---------
2916.6667
2175
1566.6667
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 15
Grouping by More
Than One Column
EMP
DEPTNO JOB SAL
--------- --------- ---------
10 MANAGER 2450
DEPTNO JOB SUM(SAL)
10 PRESIDENT 5000
-------- --------- ---------
10 CLERK 1300
10 CLERK 1300
20 CLERK 800 “sum salaries in 10 MANAGER 2450
20 CLERK 1100 the EMP table
10 PRESIDENT 5000
20 ANALYST 3000 for each job,
20 ANALYST 6000
20 ANALYST 3000 grouped by
20 CLERK 1900
20 MANAGER 2975 department”
20 MANAGER 2975
30 SALESMAN 1600
30 CLERK 950
30 MANAGER 2850
30 MANAGER 2850
30 SALESMAN 1250
30 SALESMAN 5600
30 CLERK 950
30 SALESMAN 1500
30 SALESMAN 1250
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 16
Using the GROUP BY Clause
on Multiple Columns
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 17
Illegal Queries
Using Group Functions
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 18
Illegal Queries
Using Group Functions
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 19
Excluding Group Results
EMP
DEPTNO SAL
--------- ---------
10 2450
10 5000 5000
10 1300
20 800
20 1100 “maximum DEPTNO MAX(SAL)
20 3000 salary --------- ---------
3000
20 3000 per department 10 5000
20 2975 greater than 20 3000
30 1600 $2900”
30 2850
30 1250
30 950
2850
30 1500
30 1250
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 20
Excluding Group Results: HAVING Clause
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 21
Using the HAVING Clause
DEPTNO MAX(SAL)
--------- ---------
10 5000
20 3000
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 22
Using the HAVING Clause
JOB PAYROLL
--------- ---------
ANALYST 6000
MANAGER 8275
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 23
Nesting Group Functions
MAX(AVG(SAL))
-------------
2916.6667
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 24
Summary
SELECT column, group_function(column)
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[HAVING group_condition]
[ORDER BY column];
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 25
Thank you for your attention.
Asif Sohail
Assistant Professor
University of the Punjab
Punjab University College of Information Technology (PUCIT)
Allama Iqbal (Old) Campus, Anarkali
Lahore, Pakistan
Tel: +92-(0)42-111-923-923 Ext. 154
E-mail: asif@pucit.edu.pk
© 2009 Punjab University College of Information Technology (PUCIT) September 8, 2009 Slide 26