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.
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.
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
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.
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.
Challenge: On the W3 orderDetail table, write a query that gets the number of products in each order.
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.
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:
W3's dataset has lots of related tables that you can join to get different data. Try some of the exersizes below:
- 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:
- 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:
-
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?
-
What is the difference between a Left Join and a Right Join?
- 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.
W3 SQL - This is a real treasure as a reference.
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.