Introduction
Practice SQL with the following SQLite database orgdb.db created with the script orgdb-creation.sql. You can either download and run the script and and then connect to it from R (or any other language) or download the already created database and connect to it. By using the script you learn how to create new databases (often used for creating testing and development databases).
The script has been tested in SQLite but should work with no or minor modifications also on MySQL, SQL Server, and Oracle. To write the SQL queries you can use a query console or embed the queries into {sql}
code chunks in an R Notebook – of course, after creating and then connecting to the database.
To connect to the database (once you have created or downloaded it) and execute the queries, use this R Notebook: orgdb-starter.Rmd. Of course, you can also run the queries from a query console.
Solving practice questions is the fastest way to learn any subject. The same is true for SQL. You learn SQL by doing; by writing lots of queries. So, build the queries yourself; don’t look at the solution right away. That way you will master SQL quickly.
Data Model: ERD
To create complex queries and joins, you will need a data model; if none is provided you must create one. So, inspect the database (or the database creation script) and build an ERD to help you with the queries. Alternatively, you can use a tool such as TOAD, ERwin, MySQL Workbench, or even LucidChart to build an ERD automatically.
OrgDB ERD
Practice Queries
- Retrieve the last names of all workers under the new column name LastName.
- Retrieve the first names of all workers in upper case.
- Retrieve the names of all departments without duplicates.
- Retrieve the first three characters of all last names of all workers.
- Which worker’s last names end with the character ‘a’?
- Retrieve the first names of all workers and remove any potential leading whitespace (Hint: use
ltrim()
).
- Assume that some department names have trailing whitespace. Retrieve the unique names of all departments with any trailing whitespace removed.
- Write an SQL query to list the FIRST_NAME and LAST_NAME from the Worker table into a single column COMPLETE_NAME in the form last, first, e.g., Patel, Vivek. (Hint: SQLite does not support the concat() function; instead it uses the || operator).
- Retrieve all Worker information sorted by LAST_NAME in ascending order.
- Retrieve the details for all workers with the first name of “Vipul” or “Satish”.
- Retrieve the details for all workers that do not have the first name of either “Vipul” or “Satish”.
- Which workers have a salary between 100,000 and 500,000? List their last name, first name, and salary in thousands (e.g., 100 rather than 100,000), in that order.
- How many workers have a last name that starts with ‘S’?
- Which employees joined the company in February 2014? Note that SQLite does not support the year() and month() SQL functions but does have a strftime() function. See How to Extract the Day, Month, and Year from a Date in SQLite. Or use the substr() function (See Substrings in SQLite)
- How many employees work in the department ‘Admin’?
- How many workers work for each department? List the department and number of workers in the descending order of numbers.
- List the first and last name of all workers who are managers.
- Retrieve the first five records (rows) from the Worker table sorted by salary from highest to smallest.
- Which employees have the same salary? List their last name and salary.
- Which departments that have fewer than three people in it?
- Which employees have the highest salary in each department?
- What is the total salary paid out to all employees for each department?
- Who are the employees who earn the highest salary?
- Who are the employees who earn below the average salary?
Solutions
The solutions can be found in orgdb-sql-solutions.Rmd. Of course, only look after you have exerted diligent effort in solving the queries.
To download the solution, you need to save the .Rmd file by right clicking on the link.
Disconnect from database
## Warning in connection_release(conn@ptr): Already disconnected
Conclusion
This tutorial explained the most common SQL query structures using examples.
References
Agarwal, M. (n.d.) 50 SQL Query Questions You Should Practice for Interview. link
Errata
None collected yet. Let us know.
---
title: "Practice Queries for SQL II"
params:
  category: 70
  number: 110
  time: 45
  level: beginner
  tags: "sql,joins,group by"
  description: "More 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}
```

## Introduction

Practice SQL with the following SQLite database [orgdb.db](orgdb.db) created with the script [orgdb-creation.sql](orgdb-creation.sql). You can either download and run the script and and then connect to it from R (or any other language) or download the already created database and connect to it. By using the script you learn how to create new databases (often used for creating testing and development databases).

The script has been tested in [SQLite](http://sqlite.org%5D) but should work with no or minor modifications also on MySQL, SQL Server, and Oracle. To write the SQL queries you can use a query console or embed the queries into <code>{sql}</code> code chunks in an R Notebook -- of course, after creating and then connecting to the database.

To connect to the database (once you have created or downloaded it) and execute the queries, use this R Notebook: [orgdb-starter.Rmd](orgdb-starter.Rmd). Of course, you can also run the queries from a query console.

Solving practice questions is the fastest way to learn any subject. The same is true for SQL. You learn SQL by doing; by writing lots of queries. So, build the queries yourself; don't look at the solution right away. That way you will master SQL quickly.

## Data Model: ERD

To create complex queries and joins, you will need a data model; if none is provided you must create one. So, inspect the database (or the database creation script) and build an ERD to help you with the queries. Alternatively, you can use a tool such as TOAD, ERwin, MySQL Workbench, or even LucidChart to build an ERD automatically.

![OrgDB ERD](orgdb-erd.jpeg){width="50%"}

## Practice Queries

1.  Retrieve the last names of all workers under the new column name LastName.
2.  Retrieve the first names of all workers in upper case.
3.  Retrieve the names of all departments without duplicates.
4.  Retrieve the first three characters of all last names of all workers.
5.  Which worker's last names end with the character 'a'?
6.  Retrieve the first names of all workers and remove any potential leading whitespace (Hint: use <code>ltrim()</code>).
7.  Assume that some department names have trailing whitespace. Retrieve the unique names of all departments with any trailing whitespace removed.
8.  Write an SQL query to list the FIRST_NAME and LAST_NAME from the Worker table into a single column COMPLETE_NAME in the form last, first, e.g., Patel, Vivek. (Hint: SQLite does not support the concat() function; instead it uses the \|\| operator).
9.  Retrieve all Worker information sorted by LAST_NAME in ascending order.
10. Retrieve the details for all workers with the first name of "Vipul" or "Satish".
11. Retrieve the details for all workers that do not have the first name of either "Vipul" or "Satish".
12. Which workers have a salary between 100,000 and 500,000? List their last name, first name, and salary in thousands (e.g., 100 rather than 100,000), in that order.
13. How many workers have a last name that starts with 'S'?
14. Which employees joined the company in February 2014? Note that SQLite does not support the year() and month() SQL functions but does have a strftime() function. See [How to Extract the Day, Month, and Year from a Date in SQLite](https://database.guide/how-to-extract-the-day-month-and-year-from-a-date-in-sqlite/). Or use the substr() function (See [Substrings in SQLite](https://www.sqlitetutorial.net/sqlite-functions/sqlite-substr/))
15. How many employees work in the department 'Admin'?
16. How many workers work for each department? List the department and number of workers in the descending order of numbers.
17. List the first and last name of all workers who are managers.
18. Retrieve the first five records (rows) from the Worker table sorted by salary from highest to smallest.
19. Which employees have the same salary? List their last name and salary.
20. Which departments that have fewer than three people in it?
21. Which employees have the highest salary in each department?
22. What is the total salary paid out to all employees for each department?
23. Who are the employees who earn the highest salary?
24. Who are the employees who earn below the average salary?

## Solutions

The solutions can be found in [orgdb-sql-solutions.Rmd](orgdb-sql-solutions.Rmd). Of course, only look after you have exerted diligent effort in solving the queries.

To download the solution, you need to save the *.Rmd* file by right clicking on the link.

## 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

Agarwal, M. (n.d.) 50 SQL Query Questions You Should Practice for Interview. [link](https://www.techbeamers.com/sql-query-questions-answers-for-practice/)

## 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}
```
