Beginning SQL
Beginning SQL Beginning SQL
City State Orange Town New State Windy Village Golden State Big City Mega State It may be easier to think of the ON clause as a WHERE clause that joins tables. The preceding SQL uses an AND operator to join the two conditions, but you can use any of the logical operators. Cross Joins A cross join is the most basic join, as there’s no ON clause to join the tables. Instead, all the rows from all the tables listed in the join are included in the results set. Only the usual filtering clauses associated with SELECT statements, such as a WHERE clause, limit the results set. You can define a cross join in two ways. The first way of creating a cross join uses the CROSS JOIN statement, as shown in the following code, where the Category and Location tables are cross-joined: SELECT Category, Street FROM Category CROSS JOIN Location ORDER BY Street; The preceding syntax is supported by Oracle, MySQL, and SQL Server, but not by IBM’s DB2 or MS Access. An alternative syntax for a cross join is simply to list all the tables to be cross-joined in the FROM clause, as shown here: SELECT Category, Street FROM Category, Location ORDER BY Street; Virtually all databases support the second way of cross joining, so it’s likely the best way to perform a cross join. Both of the preceding queries do the same thing and produce the same results, which are shown here: Category Street Thriller Main Street Romance Main Street Horror Main Street War Main Street Sci-fi Main Street Historical Main Street Comedy Main Street Thriller Tiny Terrace Selecting Data from Different Tables Table continued on following page 213
- Page 414: LocationId Street City State 1 Main
- Page 418: 6 Grouping and Aggregating Data So
- Page 422: Running the query, complete with a
- Page 426: MemberId Street City State 11 Newis
- Page 430: Executing the SQL returns seven dis
- Page 434: For example, the following code add
- Page 438: Running the query gives the answer
- Page 442: SELECT MAX(LastName), MIN(LastName)
- Page 446: immediately after the GROUP BY stat
- Page 450: Executing the final SQL provides th
- Page 456: Chapter 7 The INNER JOIN links the
- Page 460: Chapter 7 FilmName FirstName LastNa
- Page 464: Chapter 7 212 As mentioned, that wo
- Page 470: SELECT FM1.FilmName FROM Films AS F
- Page 474: Selecting Data from Different Table
- Page 478: effects of any WHERE clause. There
- Page 482: Now re-execute the query. You get a
- Page 486: the category list and a list of whi
- Page 490: Category FirstName LastName Horror
- Page 494: You can join the results from two o
- Page 498: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
- Page 502: function and the query still works,
- Page 506: Summary Selecting Data from Differe
- Page 512: Chapter 8 A WHERE clause is added t
City State<br />
Orange Town New State<br />
Windy Village Golden State<br />
Big City Mega State<br />
It may be easier to think of the ON clause as a WHERE clause that joins tables. The preceding <strong>SQL</strong> uses an<br />
AND operator to join the two conditions, but you can use any of the logical operators.<br />
Cross Joins<br />
A cross join is the most basic join, as there’s no ON clause to join the tables. Instead, all the rows from all<br />
the tables listed in the join are included in the results set. Only the usual filtering clauses associated with<br />
SELECT statements, such as a WHERE clause, limit the results set. You can define a cross join in two ways.<br />
The first way of creating a cross join uses the CROSS JOIN statement, as shown in the following code,<br />
where the Category and Location tables are cross-joined:<br />
SELECT Category, Street<br />
FROM Category CROSS JOIN Location<br />
ORDER BY Street;<br />
The preceding syntax is supported by Oracle, My<strong>SQL</strong>, and <strong>SQL</strong> Server, but not by IBM’s DB2 or MS<br />
Access. An alternative syntax for a cross join is simply to list all the tables to be cross-joined in the FROM<br />
clause, as shown here:<br />
SELECT Category, Street<br />
FROM Category, Location<br />
ORDER BY Street;<br />
Virtually all databases support the second way of cross joining, so it’s likely the best way to perform a<br />
cross join. Both of the preceding queries do the same thing and produce the same results, which are<br />
shown here:<br />
Category Street<br />
Thriller Main Street<br />
Romance Main Street<br />
Horror Main Street<br />
War Main Street<br />
Sci-fi Main Street<br />
Historical Main Street<br />
Comedy Main Street<br />
Thriller Tiny Terrace<br />
Selecting Data from Different Tables<br />
Table continued on following page<br />
213