Skip to content

werner33/SQL_Lessons

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 

Repository files navigation

SQL Lesson

SQL Course Overview

SQL and other query languages are used to interact with databases. As long as you work with software, you can be sure that a database - and probably more than one - is not far away. Some of you likely work with SQL on a daily basis where others might only write queries occasionally. In this class, we will review some of the basic aspects of SQL, but since you have already learned SQL basics, we will move on to some of the more advanced concepts quickly.

If you would like to review basic SQL, you can always return to the Core curriculum in Module 4.

Throughout this two part class, we will lean heavily on W3's Sql lessons and live database. NOTE: You'll want to access W3 through Chrome. Some issues have been reported with Safari.

SQL as it Relates to the Web

Given that we come at SQL as application developers, it is helpful to review how SQL relates to an overall application. First, SQL is a full language that we use when communicating with the database. However much, you use SQL, it's instructive to remember that there are whole career paths such as Data Science and Database Administration where SQL is a core skill. It is a large and robust language.

As a web developer, we may write SQL queries, but we also have the option of including one or more pieces of software to abstract the SQL and keep us working in a more familiar language. Software that allows us to access our data in a language other than SQL are called Object Relational Mapping (ORM) programs. These exist in every web stack. With Node for example, we might use Sequelize or with Ruby, we could use Active Record.

For a developer that would like to have more control over how a SQL query is composed, they might choose to use software generally called a query manager or composer. An example of this with Node would be pg-promise. With this, we are still using javascrip but when it comes to writing the actual query, it is esentially SQL with a bit of string interpolation. We need to understand SQL better to work effectively with this tool, but it gives a developer more control over how a query is structured.

There is no right or wrong here, only tradeoffs in how a web application is interacting with a database. One of the main tradeoffs is whether an ORM should be engaged to make the interations with data to be as easy as possible for the developer or whether a deeper knowledge of SQL is expected with the hope that is results in a lighter application with more efficient queries.

Basic Review of SQL

Let's quickly review one of the bedrocks of any web application CRUD: CREATE, READ, UPDATE and DELETE. Almost everything we do in a web application is one of thesefour types of actions. Now, just as a quick reminder, let's see how CRUD maps to the HTTP methods and the SQL commands:

CRUD HTTP SQL
CREATE POST INSERT INTO
READ GET SELECT
UPDATE PUT UPDATE
DELETE DELETE DELETE FROM

And to review SQL syntax quickly, our query is usually composed by starting with one of these key words. For example:

SELECT name, age, height FROM users or 'INSERT INTO users SET score=100 WHERE age > 14'

We won't spend too much time reviewing these more simple queries, but you can practice with each of them here:

SELECT UPDATE INSERT INTO DELETE

Getting Specific with Selectors

SQL is a powerful language with all kinds of syntax to help us tailor our queries. Let's look at a couple you may not be familiar with:

LIKE - LIKE is used to match text patterns in a particular column. It is somewhat similar to a regular expression in Javascript and other programing languages. Keep in mind that the text you are looking to match is case-insensitive.

Challenge: Write a query that returns any customers where the contactName has an a in the second and fifth position.

BETWEEN - BETWEEN is used to search for a value, usually a number, that lies in a bounded range. The query would look something like this :

SELECT * FROM users WHERE accountTotal BETWEEN 1000 AND 9999;

Challenge: On the order details table, write a query that returns all orders where the quantity is between 17 and 20.

Grouping

When we want to see certain records collapsed into a single row, for example, when we would like to see the number of users in a certain country, we can use GROUP BY, passing a column. All records that have that column in common will be grouped together.

GROUP BY

Challenge: On the W3 orderDetail table, write a query that gets the number of products in each order.

Joins

When we are composing a database, data will inevitably be spread across multiple tables. These tables will be related to each other through shared data. For example, we may have a User Table:

UserId Name Commits
01 Jenny 1
02 Jose 2
03 Magnolia 0
04 Rosa 1

And a Commits table:

CommitId UserId CommitMessage
01 01 Added analytics for the product detail page
02 02 Fixed Bug in adding digital products to cart
03 02 Implemented new design for home page
04 04 Handled Bug in User Profile

So here we have two tables that have a clear relationship one to the other: Users have 0 or more commits. We can see the number of commits that a User has made without accessing the Commits table, but if we want to see the messages we need to JOIN the two tables. We can do that like this:

SELECT Users.Name, Commit.id, Commit.CommitMessage
FROM Users
JOIN Commits
ON Users.UserId = Commits.UserId

And our output will look like this:

Name CommitId CommitMessage
Jenny 01 Added analytics for the product detail page
Jose 02 Fixed Bug in adding digital products to cart
Jose 03 Implemented new design for home page
Rosa 04 Handled Bug in User Profile

We've used JOIN to connect this data in a helpful way. As with any other query, we can further refine this by sorting or filtering the data.

Types of Joins

When joining two tables, we might want to pull from records that only have data present on the two tables, or some other selection. You can think of this like Venn diagram where we may want to pull only from records that join with another, ie. all Users who Have one or more Commits. This is called an INNER JOIN since it looks at the part of the Venn diagram where the circles overlap.

Let's imagine we want to find all Users with theit related Commit messages, but we still want to include Users, like Magnolia in the table above, who have made no commits. We can use a LEFT JOIN. ie give me all users and include their Commit information if there is any:

SELECT User.Name, Commit.CommitMessage
FROM Users
LEFT JOIN Commits
ON User.id = Commit.UserId;
Name CommitId CommitMessage
Jenny 01 Added analytics for the product detail page
Jose 02 Fixed Bug in adding digital products to cart
Jose 03 Implemented new design for home page
Magnolia null null
Rosa 04 Handled Bug in User Profile

Magnolia has been included because she is part of the 'Left' part of our join, the Users, even though there is nothing on the 'right' that corresponds to her UserId.

Here is a handy chart to visualize different types of Joins:

SQL_Joins

W3's dataset has lots of related tables that you can join to get different data. Try some of the exersizes below:

JOIN Exercises

  1. Create a query to join Customers with their respective Orders and create a table with: OrderDate, CustomerName and OrderId.

The beginning of the result will look like this:

Screen Shot 2021-11-29 at 3 51 10 PM

  1. Create a query to join Order with OrderDetail, getting the sum of the quantity of total items in the order.

The beginning of the result will look like this:

Screen Shot 2021-11-29 at 3 54 29 PM

Questions about Joins

  1. Given a database with Customers and Orders, where each order has a CustomerId, What kind of join would you use to find all Customers who have never placed an order?

  2. What is the difference between a Left Join and a Right Join?

More Exercises for W3

  1. The boss has offered a prize to whichever employee packed more items in the month of August of 1996. Please write a query that shows all employees by their first and last names and how many total items (not unique items, but overall quantity) that they packed in August from most to least packed.

Screen Shot 2021-11-22 at 4 43 40 PM

Articles on SQL, Query Management and ORMS

Why You Should Avoid ORMs.

ORMS are Awesome

Fun SQL Resources

W3 SQL - This is a real treasure as a reference.

LeetCode

SQL Murder Mystery - a great free game with lots of practice in more complex SQL queries.

SQL ZOO - lots of practice starting with very easy SQL to much more advanced.

SQL Police Department - This game only has a few levels for free and can feel a bit elementary, but fun none-the-less.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published