Difference between revisions of "SUM and COUNT"

From SQLZOO
Jump to: navigation, search
m
Line 17: Line 17:
 
</div>
 
</div>
  
<h2>Exercises</h2>
+
<h2>You might want to look at these examples first</h2>
 
<p>[[Using SUM, Count, MAX, DISTINCT and ORDER BY]].</p>
 
<p>[[Using SUM, Count, MAX, DISTINCT and ORDER BY]].</p>
 
+
==Total world population==
<div class="progress_panel"><div>
 
  <div class="summary">Summary</div>
 
  <div class="progressbarbg">
 
    <div class="progressbar"></div>
 
  </div>
 
</div></div>
 
 
 
 
<div class='qu'>
 
<div class='qu'>
 
Show the total '''population''' of the world.
 
Show the total '''population''' of the world.
 
                               
 
 
  world('''name''', '''continent''', '''area''', '''population''', '''gdp''')
 
  world('''name''', '''continent''', '''area''', '''population''', '''gdp''')
 
<source lang='sql' class='def'>
 
<source lang='sql' class='def'>
Line 43: Line 34:
 
</div>
 
</div>
  
 +
==List of continents==
 
<div class='qu'>
 
<div class='qu'>
 
List all the continents - just once each.  
 
List all the continents - just once each.  
Line 54: Line 46:
 
</div>
 
</div>
  
 +
==GDP of Africa==
 
<div class='qu'>
 
<div class='qu'>
 
Give the total GDP of Africa   
 
Give the total GDP of Africa   
Line 66: Line 59:
 
</div>
 
</div>
  
 +
==Count the big countries==
 
<div class='qu'>
 
<div class='qu'>
 
How many countries have an '''area''' of at least 1000000   
 
How many countries have an '''area''' of at least 1000000   
Line 78: Line 72:
 
</div>
 
</div>
  
 +
==Baltic states population==
 
<div class='qu'>
 
<div class='qu'>
What is the total '''population''' of ('France','Germany','Spain')   
+
What is the total '''population''' of ('Estonia', 'Latvia', 'Lithuania')   
 
<source lang='sql' class='def'>
 
<source lang='sql' class='def'>
 
</source>
 
</source>
Line 86: Line 81:
 
SELECT SUM(population)
 
SELECT SUM(population)
 
FROM world
 
FROM world
WHERE name IN('France','Germany','Spain')  
+
WHERE name IN ('Estonia', 'Latvia', 'Lithuania')
 
</source>
 
</source>
 
</div>
 
</div>

Revision as of 20:34, 22 February 2017

Language: English  • 中文

World Country Profile: Aggregate functions

This tutorial is about aggregate functions such as COUNT, SUM and AVG. An aggregate function takes many values and delivers just one value. For example the function SUM would aggregate the values 2, 4 and 5 to deliver the single value 11.

namecontinentarea populationgdp
AfghanistanAsia6522302550010020343000000
AlbaniaEurope28748 2831741 12960000000
AlgeriaAfrica2381741 37100000 188681000000
AndorraEurope46878115 3712000000
AngolaAfrica1246700 20609294 100990000000
...

You might want to look at these examples first

Using SUM, Count, MAX, DISTINCT and ORDER BY.

Total world population

Show the total population of the world.

world(name, continent, area, population, gdp)
SELECT SUM(population)
FROM world
SELECT SUM(population)
FROM world

List of continents

List all the continents - just once each.

SELECT DISTINCT(continent)
FROM world

GDP of Africa

Give the total GDP of Africa

SELECT SUM(gdp)
FROM world
WHERE continent = 'Africa'

Count the big countries

How many countries have an area of at least 1000000

SELECT COUNT(name)
FROM world
WHERE area >= 1000000

Baltic states population

What is the total population of ('Estonia', 'Latvia', 'Lithuania')

SELECT SUM(population)
FROM world
WHERE name IN ('Estonia', 'Latvia', 'Lithuania')

Using GROUP BY and HAVING.

For each continent show the continent and number of countries.

SELECT continent, COUNT(name)
FROM world
GROUP BY(continent)

For each continent show the continent and number of countries with populations of at least 10 million.

SELECT continent, COUNT(name)
FROM world
WHERE population >= 10000000
GROUP BY(continent)

List the continents that have a total population of at least 100 million.

SELECT continent
FROM world
GROUP BY continent
HAVING SUM(population)>= 100000000
Clear your results

The nobel table can be used to practice more SUM and COUNT functions.

The next tutorial looks at the Table Tennis database. It shows how queries may use records from two related tables.