[解決済み] "ON UPDATE CASCADE "を使用する場合について
質問
私が使っているのは
ON DELETE CASCADE
は定期的に使用しますが
ON UPDATE CASCADE
どのような場面で役に立つのかよくわからないからです。
議論のために、いくつかのコードを見てみましょう。
CREATE TABLE parent (
id INT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id)
);
CREATE TABLE child (
id INT NOT NULL AUTO_INCREMENT, parent_id INT,
INDEX par_ind (parent_id),
FOREIGN KEY (parent_id)
REFERENCES parent(id)
ON DELETE CASCADE
);
について
ON DELETE CASCADE
を持つ親がいる場合、その親は
id
が削除された場合、子レコードの
parent_id = parent.id
は自動的に削除されます。これは問題ないでしょう。
-
これは、以下のことを意味します。
ON UPDATE CASCADE
を実行すると、同じことをします。id
が更新されるのですか? -
もし(1)が真であるなら、それはつまり
ON UPDATE CASCADE
もしparent.id
のように更新されない(あるいは更新されない)。AUTO_INCREMENT
に設定されているか、常にTIMESTAMP
. これでいいのでしょうか? -
もし(2)が正しくないとしたら、他にどのような場面で
ON UPDATE CASCADE
? -
を更新した場合はどうなりますか?
child.parent_id
に変更した場合、自動的に削除されますか?
まあ、私は知っている、上記の質問のいくつかは、理解するためにプログラムでテストすることができますが、私はこのいずれかがデータベースベンダに依存するかどうかを知りたいです。
よろしくお願いします。
どのように解決するのですか?
確かに、主キーが単なる ID 値のオートインクリメントであれば
ON UPDATE CASCADE
.
しかし、主キーが10桁のUPCバーコードで、拡張のため、13桁のUPCバーコードに変更する必要があるとします。 その場合は
ON UPDATE CASCADE
を使用すると、主キーの値を変更することができ、その値を参照する外部キーがあるテーブルもそれに応じて変更されます。
4に関連して、子IDを親テーブルに存在しないものに変更した場合(そして参照整合性がある場合)、外部キーエラーが発生するはずです。
関連
-
解決策:ユーザー root で localhost:3306 にある MySQL に接続できませんでした。
-
解決策:java.sql.SQLException: ユーザー ''@'localhost'' (パスワード: YES を使用) のアクセスが拒否されました。
-
[解決済み] LINQでInclude()は何をするのですか?
-
[解決済み] SQL ServerでSELECTからUPDATEする方法とは?
-
[解決済み] SQL ServerでJOINを使用してUPDATE文を実行するにはどうすればよいですか?
-
[解決済み] INNER JOINよりもCROSS APPLYを使用すべきなのはどのような場合ですか?
-
[解決済み] SQL SELECT WHERE フィールドに単語が含まれる場合
-
[解決済み] SQLite - UPSERT *not* INSERT or REPLACE
-
[解決済み] SQLのインデックスとは何ですか?
-
[解決済み] SQL/mysql - Select distinct/UNIQUE but return all column?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
windows mysql prompt access denied for user ''@'localhost' to database.
-
org.postgresql.util.PSQLException: ERROR: リレーション "userinfo" の列 "loginid" が存在しません。
-
[解決済み] アドホッククエリとは何ですか?
-
[解決済み] テーブルネーミングのジレンマ:単数形と複数形の名前【非公開
-
[解決済み] SQL Serverでシングルクォートをエスケープするにはどうすればよいですか?
-
[解決済み] PostgreSQLからのPL/pgSQL出力をCSVファイルに保存する
-
[解決済み] SQL Serverでテーブルからカラム名を取得するにはどうすればよいですか?
-
[解決済み] SQL Serverで結果をページ分割する最も良い方法は何ですか?
-
[解決済み] SQL ServerでGROUP BYを使って文字列を連結する方法とは?
-
[解決済み] SQL/mysql - Select distinct/UNIQUE but return all column?