他のバージョンの文書 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9.6 | 9.5 | 9.4 | 9.3 | 9.2 | 9.1 | 9.0 | 8.4 | 8.3 | 8.2 | 8.1 | 8.0 | 7.4 | 7.3 | 7.2

6.2. データの更新

既にデータベースに入っているデータを変更することを「更新(update)する」と言います。 個別の行、テーブル内の全ての行、あるいは全ての行のサブセットを更新できます。 各列は、他の列に影響を及ぼすことなく個別に更新できます。

既存の行の更新を行うにはUPDATEコマンドを使用してください。 その際には3つの情報が必要となります。

  1. 更新するテーブルと列の名前

  2. 更新後の列の値

  3. 更新する行

第5章で説明した、一般にSQLでは行に対して一意のIDを指定しないことを思い出してください。 従って、どの行を更新するかを直接指定できない場合があります。 その代わりに、更新される行が満たすべき条件を指定します。 テーブルに主キーを設定している場合に限り(ユーザが宣言したのかどうかには関係なく)、主キーと一致する条件を選択することで確実に個別の行を指定できます。 グラフィカルなデータベースアクセスツールは、この方法を使用して行を個別に更新することを可能にしています。

例えば、値段が5である全ての商品の値段を10に更新するには、以下のコマンドを使用します。

UPDATE products SET price = 10 WHERE price = 5;

これによって更新される行の数はゼロであるかもしれませんし、1つ、あるいは多数であるかもしれません。 一致する行がない条件を指定して更新しようとしてもエラーにはなりません。

では、上記のコマンドの詳細を見てみましょう。 最初はUPDATEキーワードで、これにテーブル名が続きます。 いつも通り、テーブル名はスキーマで修飾することもできます。 修飾しない場合はパス内から検索されます。 次にSETキーワードがあり、これに列名、等号、そして更新後の列値が続きます。 更新後の列値は、定数だけでなく任意のスカラ式で表すことができます。 例えば、全ての商品の価格を10%上げるには以下のようにします。

UPDATE products SET price = price * 1.10;

このように、新しい値を表す式で行の中の古い値を参照することもできます。 ここでは、WHERE句を省略しました。 WHERE句を省略すると、テーブル内の全ての行が更新されます。 省略しない場合は、WHERE条件に適合する行のみが更新されます。 SET句内の等号が代入を表すのに対し、WHERE句内の等号は比較を表すことに注意してください。 ただし、これによって曖昧さが生じることはありません。 もちろん、必ずしもWHERE条件が等式でなければならないということはありません。 その他にも様々な演算子を使用することができます(第9章を参照)。 ただし、式の評価結果は論理値でなければなりません。

UPDATEコマンドのSET句に複数の代入式を列挙して、複数の列を更新することもできます。 例を示します。

UPDATE mytable SET a = 5, b = 3, c = 1 WHERE a > 0;