[解決済み] PostgreSQL の外部キーによる行の削除
質問
外部キーを含む行を削除したいのですが、以下のようにすると削除できます。
DELETE FROM osoby WHERE id_osoby='1'
こんな文が出ます。
ERROR: テーブル "osoby" の更新または削除は、テーブル "kontakty" 上の外部キー制約 "kontakty_ibfk_1" に違反します。 DETAIL キー (id_osoby)=(1) がテーブル "kontakty" からまだ参照されています。
これらの行を削除するにはどうすればよいですか。
どのように解決するのですか?
これを自動化するために、外部キー制約を
ON DELETE CASCADE
.
を引用します。
外部キー制約のマニュアル
:
CASCADE
は、参照されている行が削除されると、それを参照している行も自動的に削除されることを指定します。 も自動的に削除されるように指定します。
現在のFKの定義をこのように調べます。
SELECT pg_get_constraintdef(oid) AS constraint_def
FROM pg_constraint
WHERE conrelid = 'public.kontakty'::regclass -- assuming public schema
AND conname = 'kontakty_ibfk_1';
次に
ON DELETE ...
の部分を
ON DELETE CASCADE
(のような記述で(他はそのまま保存)。
ALTER TABLE kontakty
DROP CONSTRAINT kontakty_ibfk_1
, ADD CONSTRAINT kontakty_ibfk_1
FOREIGN KEY (id_osoby) REFERENCES osoby (id_osoby) ON DELETE CASCADE;
はありません。
ALTER CONSTRAINT
コマンドを使用します。制約を削除して再作成するには、1つの
ALTER TABLE
ステートメントを使用して、同時書き込みアクセスで起こりうる競合状態を回避します。
そうするためには、当然ながら権限が必要です。この操作には
ACCESS EXCLUSIVE
テーブルをロックします。
kontakty
と
SHARE ROW EXCLUSIVE
ロックオンテーブル
osoby
.
もし、あなたが
ALTER
テーブルを削除することができない場合、手作業(一度だけ)またはトリガーによって
BEFORE DELETE
(毎回) が残りの選択肢です。
関連
-
[解決済み] FOREIGN KEY制約で参照されているため、テーブルを切り捨てることができないのですか?
-
[解決済み] SQL ServerでSELECTからUPDATEする方法とは?
-
[解決済み] PostgreSQLの場合。PostgreSQLのテーブルを表示する
-
[解決済み] PostgreSQLの "DESCRIBE TABLE"
-
[解決済み] MySQLテーブルへの挿入または存在する場合の更新
-
[解決済み] SQL Serverでレコードを削除した後、IDシードをリセットする。
-
[解決済み] 外部キー制約のあるテーブルを切り捨てるには?
-
[解決済み] 別のテーブルに一致する項目がない行を選択するにはどうすればよいですか?
-
[解決済み】既存テーブルへの外部キー追加
-
[解決済み】MySQLで外部キー制約を追加できない
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
MHAクラスタエラーサマリーの構築
-
[解決済み] SQLのカラム名があいまいな場合のクエリエラー
-
[解決済み] 指定されたスキーマにテーブルが存在するかどうかを確認する方法
-
[解決済み] 1つのPostgreSQLクエリで複数のWITHステートメントを使用するには?
-
[解決済み] SQL Server で複数行のテキストを 1 つのテキスト文字列に連結する方法
-
[解決済み] INNER JOINよりもCROSS APPLYを使用すべきなのはどのような場合ですか?
-
[解決済み] SQL ServerにおけるINSERT OR UPDATEに関する解決策
-
[解決済み] フラットテーブルをツリーにパースする最も効率的/エレガントな方法は何ですか?
-
[解決済み] SQL Serverで結果をページ分割する最も良い方法は何ですか?
-
[解決済み] [Solved] "on delete cascade "制約を追加する方法は?