Difference between revisions of "Using nested SELECT"
(Created page with " <p>Using SELECT in SELECT</p> <p>See SELECT FROM SELECT for how to use a derived table.</p> <p>The result of a SELECT statement may be used as a value in anoth...") |
|||
| Line 1: | Line 1: | ||
<p>Using SELECT in SELECT</p> | <p>Using SELECT in SELECT</p> | ||
| − | <p>See SELECT FROM SELECT for how to use a [ | + | <p>See SELECT FROM SELECT for how to use a [http://sqlzoo.net/w/index.php/SELECT_.._SELECT derived table].</p> |
<p>The result of a SELECT statement may be used as a value in | <p>The result of a SELECT statement may be used as a value in | ||
another statement. For example the statement | another statement. For example the statement | ||
Revision as of 12:16, 12 July 2012
Using SELECT in SELECT
See SELECT FROM SELECT for how to use a derived table.
The result of a SELECT statement may be used as a value in
another statement. For example the statement
SELECT region FROM bbc WHERE name = 'Brazil'
evaluates to 'South America' so we can use this value to
obtain a list of all countries in the same region as
'Brazil'
List each country in the same region as 'Brazil'.
SELECT name FROM bbc WHERE region = (SELECT region FROM bbc WHERE name = 'Brazil')
SELECT name FROM bbc WHERE region = (SELECT region FROM bbc WHERE name = 'Brazil')
Notes
Some versions of SQL insist that you give the subquery an alias. Simply put AS somename after the closing bracket:
SELECT name FROM bbc WHERE region = (SELECT region FROM bbc WHERE name='Brazil') AS brazil_region
Multiple results from the subquery
The subquery may return more than one result - if this happens the query will fail as you are testing one value against more than one value. It is safer to use IN to cope with this possibility
The phrase (SELECT region FROM bbc WHERE name = 'Brazil' OR name='Mexico')
will return two values ('North America' and 'South America'). You should use:
SELECT name, region FROM bbc
WHERE region IN (SELECT region FROM bbc WHERE name='Brazil'
OR name='Mexico')
List each country and its region in the same region as 'Brazil' or 'Mexico'.
SELECT name, region FROM bbc WHERE region IN (SELECT region FROM bbc WHERE name='Brazil' OR name ='Mexico')