Unit 4 Queries and Joins
Key Concepts Using the SELECT statement Statement clauses Subqueries Multiple table statements Using table pseudonyms Inner joins Outer joins Cross joins Explicit joins Additional conditions Other joins
SELECT Statement SELECT (column list or expressions) FROM (table list) WHERE (filter and join conditions)
Using SELECT Statements Introduction to SQL, Figure 6.1, pg. 156
SELECT Statements SELECT clause is always required. SELECT and FROM clauses are required if using WHERE, GROUP BY, HAVING or ORDER BY. A HAVING clause requires a GROUP BY clause. Clause order is fixed: –SELECT clause must be first –ORDER BY clause (if used) must be last
Sample Introduction to SQL, Example 6.1, pg. 160
SELECT Processing Introduction to SQL, Figure 6.3, pg. 161
UNION Operator Put the two statement examples at the top of page 170 side-by-side on the slide.
Subquery Introduction to SQL, Example 6.6, pg. 171
Subquery (cont'd) Introduction to SQL, Example 6.9, pg. 176
Multiple Table Specification (Joining Tables) Introduction to SQL, Example 7.6, pg. 189.
Join Example Introduction to SQL, Example 7.7, pg. 191.
Table Pseudonyms Introduction to SQL, Example 7.8, pg. 194 and Example 7.12, pg. 198.
Required Pseudonyms Introduction to SQL, Example 7.14, pg. 199.
Explicit Join Introduction to SQL, Example 7.16, pg. 205
USING Keyword SELECT TEAMNO, NAME FROM TEAMS INNER JOIN PLAYERS USING (PLAYERNO)
Outer Join Left outer join returns all rows from the left table and qualifying rows from the right table. Right outer join returns all rows from the right table and qualifying rows from the left table. Full outer join returns all rows from both tables. Depending on the DBMS, A question mark (?) or NULL is used in the result set where there is no value returned. SQL Server returns a NULL.
Left Outer Join Introduction to SQL, Example 7.17, pg. 207.
Right Outer Join Introduction to SQL, Example 7.21, pg. 211.
Full Outer Join Introduction to SQL, Example 7.22, pg. 212.
Additional Conditions WHERE Clause Introduction to SQL, Example 7.23, pg. 216
Additional Conditions FROM Clause SELECT TEAMS.PLAYERNO, TEAMS.TEAMNO, PENALTIES.PAYMENTNO FROM TEAMS LEFT OUTER JOIN PENALTIES ON TEAMS.PLAYERNO = PENALTIES.PLAYERNO AND DIVISION = 'second'
Other Joins UNION join NATURAL join Equi join Theta join
Subquery Example SELECT Fname, Lname, DepartName FROM (SELECT E.EmployeeID, DepartName FROM Employee E, Department D WHERE E.Department = D.DepartmentID) AS SQ, Person P WHERE SQ.EmployeeID = P.EmployeeID ORDER BY Lname, Fname