Difference between revisions of "Using nested SELECT/zh"

From SQLZOO
Jump to: navigation, search
 
Line 1: Line 1:
反回 [[SELECT within SELECT Tutorial|SELECT中的SELECT練習]]
+
反回 [[SELECT within SELECT Tutorial/zh|SELECT中的SELECT練習]]
 
==如何使用SELECT中的SELECT==
 
==如何使用SELECT中的SELECT==
 
<p>See SELECT FROM SELECT for how to use a [http://sqlzoo.net/w/index.php/SELECT_.._SELECT derived table].</p>
 
<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>SELECT查詢的結果可以當作一個值,用在另一個查詢當中,例如
    another statement. For example the statement
 
 
     <b>SELECT continent FROM world WHERE name = 'Brazil'</b>
 
     <b>SELECT continent FROM world WHERE name = 'Brazil'</b>
  
     evaluates to <code>'South America'</code> so we can use this value to
+
     得到結果 <code>'South America'</code> ,所以我們可以用此值來找出與巴西'Brazil'同一洲份的全部國家。</p>
    obtain a list of all countries in the same continent as
 
    'Brazil'</p>
 
  
 
<div class='qu'>
 
<div class='qu'>
Line 19: Line 16:
 
</div>
 
</div>
  
==Alias==
+
==別名==
<p>Some versions of SQL insist that you give the subquery an <i>alias</i>. Simply put <code>AS somename</code> after the closing bracket:
+
<p>在某些SQL系統中,子查詢中有時必須使用<i>別名</i>, 當作新的表格名. 只需加上 <code>AS 別名</code> 在括號之後:
 
<pre>
 
<pre>
 
SELECT name FROM world WHERE continent =  
 
SELECT name FROM world WHERE continent =  
Line 27: Line 24:
 
</p>
 
</p>
  
==Multiple Results==
+
==多於一個結果==
 +
子查詢有時會得出多於一個結果-如出現,而你又對此結果進行值的比較,會出現錯誤。
 +
可能的話,使用IN會更加安全。
  
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 continent FROM world WHERE name = 'Brazil' OR name='Mexico')</code>
+
查詢<code>(SELECT continent FROM world WHERE name = 'Brazil' OR name='Mexico')</code>
will return two values ('North America' and 'South America'). You should use:
+
會得到兩個值('North America' 'South America'). 你應使用:
 
  SELECT name, continent FROM world
 
  SELECT name, continent FROM world
 
  WHERE continent IN
 
  WHERE continent IN
Line 40: Line 37:
  
 
<div class='qu'>
 
<div class='qu'>
List each country and its continent in the same continent as 'Brazil' or 'Mexico'.
+
列出與巴西'Brazil' 和 墨西哥'Mexico'相同洲份的每個國家名和洲份。
 
<source lang='sql' class='def'>
 
<source lang='sql' class='def'>
 
SELECT name, continent FROM world
 
SELECT name, continent FROM world
Line 50: Line 47:
 
</div>
 
</div>
  
==Subquery on the SELECT line==
+
==SELECT語句中的子查詢==
If you are certain that only one value will be returned you can use that query on the SELECT line.
+
如你保證子查詢只會有一個結果,你可以在SELECT語句中使用子查詢。
 
<div class='qu'>
 
<div class='qu'>
<p class='imper'>Show the population of China as a multiple of the population of the United Kingdom</p>
+
<p class='imper'>顯示中國人口是英國人口的多少倍。</p>
 
<source lang='sql' class='def'>
 
<source lang='sql' class='def'>
 
SELECT
 
SELECT
Line 63: Line 60:
 
</div>
 
</div>
  
==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.
+
你可以使用 ALL ANY ,當運算子的右面有多於一個值的時候。
 
<div class='qu'>
 
<div class='qu'>
<p class='imper'>Show each country that has a population greater than the population of ALL countries in Europe.</p>
+
<p class='imper'>找出哪些國家的人口是高於歐洲每一國的人口。\</p>
Note that we mean greater than every single country in Europe; not the combined population of Europe.
+
留意,我們是找高於歐洲每一個單一國家的人口,不是歐洲各國合計的全部總人口。
 
<source lang='sql' class='def'>
 
<source lang='sql' class='def'>
 
SELECT name FROM world
 
SELECT name FROM world
Line 82: Line 79:
 
</div>
 
</div>
  
Return to the [[SELECT within SELECT Tutorial]]
+
返回 [[SELECT within SELECT Tutorial/zh|SELECT中的SELECT練習]]

Latest revision as of 16:47, 26 March 2016

反回 SELECT中的SELECT練習

如何使用SELECT中的SELECT

See SELECT FROM SELECT for how to use a derived table.

SELECT查詢的結果可以當作一個值,用在另一個查詢當中,例如 SELECT continent FROM world WHERE name = 'Brazil' 得到結果 'South America' ,所以我們可以用此值來找出與巴西'Brazil'同一洲份的全部國家。

List each country in the same continent as 'Brazil'.

SELECT name FROM world WHERE continent = 
(SELECT continent 
FROM world WHERE name = 'Brazil')

別名

在某些SQL系統中,子查詢中有時必須使用別名, 當作新的表格名. 只需加上 AS 別名 在括號之後:

SELECT name FROM world WHERE continent = 
  (SELECT continent FROM world WHERE name='Brazil') AS brazil_continent

多於一個結果

子查詢有時會得出多於一個結果-如出現,而你又對此結果進行值的比較,會出現錯誤。 可能的話,使用IN會更加安全。


查詢(SELECT continent FROM world WHERE name = 'Brazil' OR name='Mexico') 會得到兩個值('North America' 和 'South America'). 你應使用:

SELECT name, continent FROM world
WHERE continent IN
 (SELECT continent FROM world WHERE name='Brazil'
                                 OR name='Mexico')

列出與巴西'Brazil' 和 墨西哥'Mexico'相同洲份的每個國家名和洲份。

SELECT name, continent FROM world
WHERE continent IN
  (SELECT continent 
     FROM world WHERE name='Brazil'
                   OR name='Mexico')

SELECT語句中的子查詢

如你保證子查詢只會有一個結果,你可以在SELECT語句中使用子查詢。

顯示中國人口是英國人口的多少倍。

SELECT
 population/(SELECT population FROM world
             WHERE name='United Kingdom')
  FROM world
WHERE name = 'China'

對一個集合使用運算子

這些運算子是二元的,即它要兩個數值運作。:

=     等於
>     大於
<     小於
>=    大於或等於
<=    小於或等於

你可以使用 ALL 或 ANY ,當運算子的右面有多於一個值的時候。

找出哪些國家的人口是高於歐洲每一國的人口。\

留意,我們是找高於歐洲每一個單一國家的人口,不是歐洲各國合計的全部總人口。

SELECT name FROM world
 WHERE population > ALL
      (SELECT population FROM world
        WHERE continent='Europe')

返回 SELECT中的SELECT練習