前節で示したように、SELECTコマンド中のテーブル式は、テーブルの結合やビュー、行の抽出、グループ化などにより中間の仮想テーブルを作ります。 このテーブルは最終的に選択リストに渡されます。 選択リストは、中間のテーブルのどの列が実際に出力されるかを決めます。
テーブル式が生成するすべての列を出力する*が最も簡単な選択リストです。 そうでなければ、選択リストは、カンマで区切られた(項4.2で定義された)評価式のリストです。 たとえば、以下のような列名のリストであってもかまいません。
SELECT a, b, c FROM ...
a、b、cという列名は、FROM句で参照されるテーブルの実際の列名か、あるいは、項7.2.1.2で説明したような列名に対する別名です。 グルーピングされていなければ、選択リストで使用可能な名前空間はWHERE句と同じです。 グルーピングされている場合は、HAVING 句と同じとなります。
もし、2つ以上のテーブルで同じ名前の列がある場合は、次のように、テーブル名を必ず指定しなければいけません
SELECT tbl1.a, tbl2.a, tbl1.b FROM ...
複数のテーブルを使用する場合、特定のテーブルを列すべてに付与する方が便利かもしれません。
SELECT tbl1.*, tbl2.a FROM ...
(項7.2.2も参照してください。)
任意の評価式が選択リストで使われる場合、返されるテーブルは、概念的には新たに仮想的な列を追加したものとなります。 評価式は、それぞれの結果行で、その列参照を置換した行の値として一旦評価されます。 しかし、選択リストの式はFROM 句で指定されたテーブル式内の列を参照するものである必要はありません。 たとえば、それらは定数算術式でもかまいません。
選択リスト中の項目は後の処理のために名前を割り当てることができます。 この場合の"後の処理"とは、オプションのソート指定やクライアントアプリケーションのことです(たとえば、列へッダを表示するために使います)。 例を示します。
SELECT a AS value, b + c AS sum FROM ...
もし、ASを使った列名の指定が無かった場合、システムは、デフォルトの名前を割り当てます。 単純な列の参照では、参照された列名となります。 関数呼び出しでは、関数名となります。 複雑な表現については、システムが汎用の名前を生成します。
注意: ここでの出力列の名前は、FROM句(項7.2.1.2を参照)で示したものとは異なります。 パイプ処理で、同じ列を2度改名することが可能ですが、選択リストの中で選ばれた名前が渡されます。
選択リストが処理された後、結果テーブルの重複データを削除の対象にすることもできます。 これを行うには、SELECTの直後にDISTINCTキーワードを指定します。
SELECT DISTINCT select_list ...
(DISTINCTの代わりにALLを指定すると、すべての行がデフォルトで保持されます。)
少なくとも1つの列の値が異なる場合、それら2行は別個とみなされます。 NULL 値は、この比較において等しいとみなされます。
また、任意の式を使用して、どの行が別であるかを決定することもできます。
SELECT DISTINCT ON (expression [, expression ...]) select_list ...
expressionは、すべての行で評価される任意の評価式です。 全ての式が等しくなる行の集合は、重複しているとみなされ、集合の最初の行だけが出力されます。 DISTINCTフィルタにかけられる行の順序の一意性を保証できるよう問い合わせが列をソートしない限り、出力される集合の"最初の行"は予想不可能であることに注意してください。 (DISTINCT ON処理は、ORDER BYによるソートの後に行われます。)
DISTINCT ON句は、標準SQLではありません。さらに、結果が不定となる可能性があるため、好ましくないスタイルとみなされることもあります。 GROUP BYとFROM中の副問い合わせをうまく使うことによりにこの構文を使わずに済みます。 しかし、DISTINCT ON句は多くの場合非常に便利な代案となります。