Sample Database
This commands below create the SQLite “projectdb2.db” database containing the tables projects, projectmgr, certification and earnedcerts. Inspect the schema creation statements to understand the structure of the database.
library(RSQLite)
# create a new in-memory database
dbcon <- dbConnect(RSQLite::SQLite(), ":memory:")
create table projectmgr (
pmid integer,
name text not null,
primary key (pmid)
)
create table certifications (
cid integer not null,
cert text not null,
body text not null,
primary key (cid)
)
create table earnedcerts (
pmid integer,
cert integer,
primary key (pmid,cert)
foreign key (pmid) references projectmgr(pmid)
foreign key (cert) references certifications(cid)
)
create table projects (
pid integer,
pname text default "No Name",
budget double default 0,
pmgr integer not null,
primary key (pid),
foreign key (pmgr) references projectmgr(pmid)
)
insert into certifications values
(1,"PMP","Project Management Institute"),
(2,"APM","Project Management Institute"),
(4,"CBAP","International Institute of Business Analysis"),
(5,"CIPM","American Academy of Project Management")
insert into projectmgr values
(11,"John Wu"),
(22,"Ann Molloy"),
(18,"Sandeep Ranghani"),
(19,"Alicia Knauss"),
(38,"Roxanna da Silva"),
(23,"Wagner Ormond"),
(47,"Margaret O'Shea"),
(20,"Alden White")
insert into earnedcerts values
(11,1),
(11,4),
(18,1),
(22,1),
(47,1),
(20,1),
(20,4),
(38,5)
insert into projects values
(100,"GOTAM",350000,11),
(200,"Data Twist",875000,20),
(300,"Alpha Launch",12500,18),
(302,"Alpha Arch Design",38000,18),
(303,"Alpha Dev",125000,18),
(305,"Alpha Analytics Dashboard",235000,38),
(811,"Bootstrap Demo",0,47)
---
title: "Practice Queries for SQL I"
params:
  category: 70
  number: 109
  time: 45
  level: beginner
  tags: "sql,joins,group by"
  description: "Uses examples to explain the basic query structure of SQL
                and the most common types of queries. Demonstrates selection
                from a single table, aliases, filtering with WHERE, inner joins,
                grouping with GROUP BY, and aggregation."
date: "<small>`r Sys.Date()`</small>"
author: "<small>Martin Schedlbauer</small>"
email: "m.schedlbauer@neu.edu"
affilitation: "Northeastern University"
output: 
  bookdown::html_document2:
    toc: true
    toc_float: true
    collapsed: false
    number_sections: false
    code_download: true
    theme: spacelab
    highlight: tango
---

---
title: "<small>`r params$category`.`r params$number`</small><br/><span style='color: #2E4053; font-size: 0.9em'>`r rmarkdown::metadata$title`</span>"
---

```{r code=xfun::read_utf8(paste0(here::here(),'/R/_insert2DB.R')), include = FALSE}
```

## Sample Database

This commands below create the SQLite "projectdb2.db" database containing the tables **projects**, **projectmgr**, **certification** and **earnedcerts**. Inspect the schema creation statements to understand the structure of the database.

```{r}
library(RSQLite)

# create a new in-memory database
dbcon <- dbConnect(RSQLite::SQLite(), ":memory:")
```

```{sql connection=dbcon}
create table projectmgr (
  pmid integer,
  name text not null,
  primary key (pmid)
)
```

```{sql connection=dbcon}
create table certifications (
  cid integer not null,
  cert text not null,
  body text not null,
  primary key (cid)
)
```

```{sql connection=dbcon}
create table earnedcerts (
  pmid integer,
  cert integer,
  primary key (pmid,cert)
  foreign key (pmid) references projectmgr(pmid)
  foreign key (cert) references certifications(cid)
)
```

```{sql connection=dbcon}
create table projects (
  pid integer,
  pname text default "No Name",
  budget double default 0,
  pmgr integer  not null,
  primary key (pid),
  foreign key (pmgr) references projectmgr(pmid)
)
```

```{sql connection=dbcon}
insert into certifications values
  (1,"PMP","Project Management Institute"),
  (2,"APM","Project Management Institute"),
  (4,"CBAP","International Institute of Business Analysis"),
  (5,"CIPM","American Academy of Project Management")
```

```{sql connection=dbcon}
insert into projectmgr values
  (11,"John Wu"),
  (22,"Ann Molloy"),
  (18,"Sandeep Ranghani"),
  (19,"Alicia Knauss"),
  (38,"Roxanna da Silva"),
  (23,"Wagner Ormond"),
  (47,"Margaret O'Shea"),
  (20,"Alden White")
```

```{sql connection=dbcon}
insert into earnedcerts values
  (11,1),
  (11,4),
  (18,1),
  (22,1),
  (47,1),
  (20,1),
  (20,4),
  (38,5)
```

```{sql connection=dbcon}
insert into projects values
  (100,"GOTAM",350000,11),
  (200,"Data Twist",875000,20),
  (300,"Alpha Launch",12500,18),
  (302,"Alpha Arch Design",38000,18),
  (303,"Alpha Dev",125000,18),
  (305,"Alpha Analytics Dashboard",235000,38),
  (811,"Bootstrap Demo",0,47)
```

## Sample Queries

### List all information about project managers

```{sql connection=dbcon}
select * from projectmgr
```

### List all information about projects

```{sql connection=dbcon}
select * from projects
```

### List all information about certifications

```{sql connection=dbcon}
select * from certifications
```

```{sql connection=dbcon}
select * from earnedcerts
```

### List the names and budgets of all projects with a budget of more than \$200,000.

```{sql connection=dbcon}
select p.pname, p.budget 
  from projects p
 where p.budget > 200000;
```

### How many projects managers are there?

```{sql connection=dbcon}
select count(*) as 'NumPMs'
  from projectmgr;
```

### List the names of all project managers who manage at least one project, ordered alphabetically in descending order starting with 'A'.

```{sql connection=dbcon}
select distinct m.name
  from projectmgr m join projects p on (m.pmid = p.pmgr)
 order by m.name;
```

### List the names of all project managers who do not manage at least one project.

```{sql connection=dbcon}
select name
  from projectmgr
 except
select distinct m.name
  from projectmgr m join projects p on (m.pmid = p.pmgr)
```

### List all project names and the name of the project manager.

```{sql connection=dbcon}
select p.pname, m.name
  from projects p join projectmgr m on (m.pmid = p.pmgr);
```

### What is the total budget of all projects combined?

```{sql connection=dbcon}
select sum(p.budget)
  from projects p;
```

### Which project managers have more than one certification?

```{sql connection=dbcon}
select m.name, count(*) as 'NumCerts'
  from earnedcerts e join projectmgr m on (e.pmid = m.pmid)
 group by e.pmid
having NumCerts > 1
```

### List the name of each project manager, the number of projects they manage, and the total combined budget of their projects.

```{sql connection=dbcon}
select m.name, count(*) as 'NumProjects', sum(p.budget) as 'TotalBudget'
  from projectmgr m join projects p on (m.pmid = p.pmgr)
 group by p.pmgr
```

### List all projects that have a project name that contains the text "Alpha".

```{sql connection=dbcon}
select *
  from projects p
 where p.pname like '%Alpha%';
```

### What is the average project budget?

```{sql connection=dbcon}
select avg(p.budget) from projects p
```

### Which projects are within 10% of the average budget.

```{sql connection=dbcon}
select *
  from projects p
 where p.budget > 0.9*(select avg(p.budget) from projects p)
   and p.budget < 1.1*(select avg(p.budget) from projects p);
```

### Which project managers do not have any certifications? List their names.

```{sql connection=dbcon}
select p.name
  from projectmgr p
 where p.pmid not in (select distinct e.pmid
                        from earnedcerts e);
```

## Disconnect from Database

```{r}
dbDisconnect(dbcon)
```

## Conclusion

This tutorial explained the most common SQL query structures using examples.

------------------------------------------------------------------------

## Files & Resources

```{r zipFiles, echo=FALSE}
zipName = sprintf("LessonFiles-%s-%s.zip", 
                 params$category,
                 params$number)

textALink = paste0("All Files for Lesson ", 
               params$category,".",params$number)

# downloadFilesLink() is included from _insert2DB.R
knitr::raw_html(downloadFilesLink(".", zipName, textALink))
```

------------------------------------------------------------------------

## References

No references.

## Errata

None collected yet. Let us know.

```{=html}
<script src="https://form.jotform.com/static/feedback2.js" type="text/javascript">
  new JotformFeedback({
    formId: "212187072784157",
    buttonText: "Feedback",
    base: "https://form.jotform.com/",
    background: "#F59202",
    fontColor: "#FFFFFF",
    buttonSide: "left",
    buttonAlign: "center",
    type: false,
    width: 700,
    height: 500,
    isCardForm: false
  });
</script>
```
```{r code=xfun::read_utf8(paste0(here::here(),'/R/_deployKnit.R')), include = FALSE}
```
