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...") |
(→Using a query on the SELECT line) |
||
| (11 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| − | + | Return to the [[SELECT within SELECT Tutorial]] | |
| − | <p>See SELECT FROM SELECT for how to use a [ | + | ==Using SELECT in SELECT== |
| + | <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 | ||
| Line 31: | Line 32: | ||
</pre> | </pre> | ||
</p> | </p> | ||
| − | |||
| − | + | ==Multiple results from the subquery== | |
| − | you are testing one value against more than one value. It is safer to use IN to cope with | + | |
| − | this possibility | + | The subquery may return more than one result - if this happens the query above 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 <code>(SELECT region FROM bbc WHERE name = 'Brazil' OR name='Mexico')</code> | ||
will return two values ('North America' and 'South America'). You should use: | 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' | + | WHERE region IN (SELECT region FROM bbc WHERE name='Brazil' |
| − | + | OR name='Mexico') | |
| Line 46: | Line 48: | ||
List each country and its region in the same region as 'Brazil' or 'Mexico'. | List each country and its region in the same region as 'Brazil' or 'Mexico'. | ||
<source lang='sql' class='def'> | <source lang='sql' class='def'> | ||
| − | |||
| − | |||
| − | |||
SELECT name, region FROM bbc | SELECT name, region FROM bbc | ||
WHERE region IN (SELECT region | WHERE region IN (SELECT region | ||
| − | FROM bbc WHERE name='Brazil' | + | FROM bbc WHERE name='Brazil' |
| − | OR name ='Mexico') | + | OR name ='Mexico') |
</source> | </source> | ||
</div> | </div> | ||
| + | |||
| + | ==Using a subquery on the SELECT line== | ||
| + | If you are certain that only one value will be returned you can use that query on the SELECT line. | ||
| + | <div class='qu'> | ||
| + | <p class='imper'>Show the population of China as a multiple of the population of the United Kingdom</p> | ||
| + | <source lang='sql' class='def'> | ||
| + | SELECT population/(SELECT population FROM bbc | ||
| + | WHERE name='United Kingdom') | ||
| + | FROM bbc | ||
| + | WHERE name = 'China' | ||
| + | </source> | ||
| + | </div> | ||
| + | |||
| + | ==Using binary operators over a set== | ||
| + | These operators are ''binary'' - they normally take two parameters: | ||
| + | = equals | ||
| + | > greater than | ||
| + | < less than | ||
| + | >= greater or equal | ||
| + | <= less or equal | ||
| + | You can use the words ALL or ANY where the right side of the operator might have multiple values. | ||
| + | <div class='qu'> | ||
| + | <p class='imper'>Show each country that has a population greater than the population of ALL countries in Europe.</p> | ||
| + | Note that we mean greater than every single country in Europe; not the combined population of Europe. | ||
| + | <source lang='sql' class='def'> | ||
| + | SELECT name FROM bbc | ||
| + | WHERE population > ALL | ||
| + | (SELECT population FROM bbc | ||
| + | WHERE region='Europe') | ||
| + | </source> | ||
| + | </div> | ||
| + | |||
| + | Return to the [[SELECT within SELECT Tutorial]] | ||
Revision as of 19:30, 22 August 2012
Return to the SELECT within SELECT Tutorial
Contents |
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 above 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')
Using a subquery on the SELECT line
If you are certain that only one value will be returned you can use that query on the SELECT line.
Show the population of China as a multiple of the population of the United Kingdom
SELECT population/(SELECT population FROM bbc WHERE name='United Kingdom') FROM bbc WHERE name = 'China'
Using binary operators over a set
These operators are binary - they normally take two parameters:
= equals > greater than < less than >= greater or equal <= less or equal
You can use the words ALL or ANY where the right side of the operator might have multiple values.
Show each country that has a population greater than the population of ALL countries in Europe.
Note that we mean greater than every single country in Europe; not the combined population of Europe.
SELECT name FROM bbc WHERE population > ALL (SELECT population FROM bbc WHERE region='Europe')
Return to the SELECT within SELECT Tutorial