3.48k likes | 6.25k Views
SQL JOINS. WHY USE A JOIN?. The SQL JOIN clause is used whenever we have to select data from 2 or more tables. HOW TO USE A JOIN. To be able to use the SQL JOIN clause to extract data from 2 (or more) tables, we need a relationship between certain columns in these tables. .
E N D
WHY USE A JOIN? • The SQL JOIN clause is used whenever we have to select data from 2 or more tables
HOW TO USE A JOIN • To be able to use the SQL JOIN clause to extract data from 2 (or more) tables, we need a relationship between certain columns in these tables.
TABLES USED FOR EXAMPLES CUSTOMER TABLE: SALES TABLE: THE COMMON FIELD IS CustomerID
FIRST JOIN • Select all distinct customers (their first and last names) and the total respective amount of dollars they have spent. The SQL JOIN condition has been specified after the SQL WHERE clause and says that the 2 tables have to be matched by their respective CustomerID columns.
USE ‘JOIN’ INSTEAD OF ‘WHERE’ NOTICE THE USE OF ‘ON’ WITH THE JOIN COMMAND
TWO (2) TYPES OF JOINS • Inner Join • When you use the ‘JOIN’ command , inner join is the default • Will select all rows from both tables as long as there is a match between the columns being matched
INNER JOIN EXAMPLE • What if the Sales table only had the following: • And we use the same JOIN statement as before
RESULT? Even though Paul and James are listed in the Customers table, they won’t be displayed because they haven’t ordered anything yet.
OUTER JOIN2 SUB-TYPES • Left Outer Join • Simply used as ‘left join’ (outer is not required) • selects all the rows from the first table listed after the FROM clause, no matter if they have matches in the second table.
LEFT JOIN EXAMPLE • What if we wanted to list all the customers and their sales even if they haven’t placed an order? The sales table still has the following:
LEFT JOIN EXAMPLE cont’d SELECT Customers.FirstName, Customers.LastName, SUM(Sales.SaleAmount) AS SalesPerCustomerFROM Customers LEFT JOIN SalesON Customers.CustomerID = Sales.CustomerIDGROUP BY Customers.FirstName, Customers.LastName Replaced JOIN with LEFT JOIN
RESULT? Everything from the Customers (first table) has been selected. For all rows from Customers, which don’t have a match in the Sales (second table), the SalesPerCustomer column has amount NULL (NULL means a column contains nothing).
RIGHT OUTER JOIN • Simply used as ‘left join’ (outer is not required) • Behaves exactly as SQL LEFT JOIN, except that it returns all rows from the second table (the right table in our SQL JOIN statement).
CARTESIAN PRODUCT • If the left table has 10 rows and the right table has 18 rows then SQL Join (if not written correctly) will return 180 rows combining each record of left table with all records of right side table.