v Calculate Counts, Sums, Max, and Averages - SQL

# Calculate Counts, Sums, Max, and Averages

Note: This tutorial was written using Catherine Devlin's SQL in Jupyter Notebooks library. If you have not using a Jupyter Notebook, you can ignore the two lines of code below and any line containing `%%sql`. Furthermore, this tutorial uses SQLite's flavor of SQL, your version might have some differences in syntax.

For more, check out Learning SQL by Alan Beaulieu.

```# Ignore
%sql sqlite://
%config SqlMagic.feedback = False
```

## Create Data

```%%sql

-- Create a table of criminals
CREATE TABLE criminals (pid, name, age, sex, city, minor);
INSERT INTO criminals VALUES (412, 'James Smith', 15, 'M', 'Santa Rosa', 1);
INSERT INTO criminals VALUES (234, 'Bill James', 22, 'M', 'Santa Rosa', 0);
INSERT INTO criminals VALUES (632, 'Stacy Miller', 23, 'F', 'San Francisco', 0);
INSERT INTO criminals VALUES (901, 'Gordon Ado', 32, 'F', 'San Francisco', 0);
INSERT INTO criminals VALUES (512, 'Bill Byson', 21, 'M', 'Petaluma', 0);
```
```[]
```

## View Average Ages By City

```%%sql

--  Select name and average age,
SELECT city, avg(age)

--  from the table 'criminals',
FROM criminals

-- after grouping by city
GROUP BY city
```
city avg(age)
Petaluma 21.0
San Francisco 27.5
Santa Rosa 18.5

## View Max Age By City

```%%sql

--  Select name and average age,
SELECT city, max(age)

--  from the table 'criminals',
FROM criminals

-- after grouping by city
GROUP BY city
```
city max(age)
Petaluma 21
San Francisco 32
Santa Rosa 22

## View Count Of Criminals By City

```%%sql

--  Select name and average age,
SELECT city, count(name)

--  from the table 'criminals',
FROM criminals

-- after grouping by city
GROUP BY city
```
city count(name)
Petaluma 1
San Francisco 2
Santa Rosa 2

## View Total Age By City

```%%sql

--  Select name and average age,
SELECT city, total(age)

--  from the table 'criminals',
FROM criminals

-- after grouping by city
GROUP BY city
```
city total(age)
Petaluma 21.0
San Francisco 55.0
Santa Rosa 37.0