4

MySQLで次のことを行います。

alter table TABLE_A 
ADD CONSTRAINT fk_id (id) REFERENCES TABLE_B(id) 
ON DELETE CASCADE ON UPDATE CASCADE;

と同じことをします

alter table TABLE_A 
ADD FOREIGN KEY (id) REFERENCES TABLE_B(id);

関係にBTREEインデックスも追加することを除いて?それとも、それらは互いに補完し合っていますか?

4

2 に答える 2

5

マニュアルによると、両方のクエリに存在するFOREIGN KEY必要がありますが、両方のクエリはほぼ同じです。

[CONSTRAINT [symbol]] FOREIGN KEY
[index_name] (index_col_name, ...)
REFERENCES tbl_name (index_col_name,...)
[ON DELETE reference_option]
[ON UPDATE reference_option]

の利点はCONSTRAINT [symbol]、MySQLが名前を生成するのではなく、制約に名前を付けることができることです。このシンボルはデータベース内で一意である必要があり、後で制約を削除するために使用できます。

生成されたシンボル名は、作成後にテーブル構造を確認することで確認できます。

SHOW CREATE TABLE TABLE_A;
于 2012-11-26T14:49:39.617 に答える
0

CONSTRAINT構文は純粋に名前付けを目的としているため、その名前を使用して、テーブルの他の列に制約を実装できます。

質問に対するあなたの答え

于 2014-02-19T07:19:33.893 に答える