DELETE

Name

DELETE  --  テーブルから行を削除する。

Synopsis

DELETE FROM table [ WHERE condition ]
  

入力

table

既存のテーブル名。

condition

削除すべき行を返す、SQL の選択問い合わせ。

WHERE 句についてのより詳細については、SELECT 文を参照して下さい。

出力

DELETE count

各行が正常に削除された時に返されるメッセージ。 count は削除された 行数を示します。

count が 0 の場合、 行が削除されなかったことを示します。

説明

DELETE は指定したテーブルから WHERE 句を満たす 行を削除します。

condition (WHERE 句) がない場合、指定 テーブルの全ての行を削除することになります。 その結果、テーブルは有効のまま空になります。

Tip: Postgres の拡張言語である、 TRUNCATE は、より高速にテーブルから全ての行を削除する機構を提供します。

テーブルを変更するために書き込み権限が必要です。同様に condition 内 で読み込まれる値を持つテーブルへの読み込み権限も必要にな ります。

使用法

films テーブルから musicals 以外を全て削除します。

DELETE FROM films WHERE kind <> 'Musical';
SELECT * FROM films;

 code  |           title           | did | date_prod  |  kind   | len
-------+---------------------------+-----+------------+---------+-------
 UA501 | West Side Story           | 105 | 1961-01-03 | Musical | 02:32
 TC901 | The King and I            | 109 | 1956-08-11 | Musical | 02:13
 WD101 | Bed Knobs and Broomsticks | 111 |            | Musical | 01:57
(3 rows)

films テーブルを空にします。

DELETE FROM films;
SELECT * FROM films;

 code | title | did | date_prod | kind | len
------+-------+-----+-----------+------+-----
(0 rows)

互換性

SQL92

SQL92 では、位置による DELETE 文が可能です。

DELETE FROM table WHERE
    CURRENT OF cursor
    
ここで、cursor はオープ ン済みのカーソルの識別子です。 Postgres の対話式カーソルは読み取り専用です。