對(duì)于許多MySQL開發(fā)者來說,級(jí)聯(lián)刪除視圖是一個(gè)值得探討的話題。然而,從我個(gè)人的經(jīng)驗(yàn)來看,這種方法并不總是最好的。以下是我觀察到的一些問題:
CREATE TABLE table1 ( id int(11) NOT NULL PRIMARY KEY, name varchar(20) ); CREATE TABLE table2 ( id int(11) NOT NULL PRIMARY KEY, name varchar(20), table1_id int(11) REFERENCES table1(id) ON DELETE CASCADE ); CREATE VIEW view1 AS SELECT * FROM table1 JOIN table2 ON table1.id = table2.table1_id; DELETE FROM table1 WHERE id = 1;
上述代碼展示了如何創(chuàng)建一個(gè)包含兩個(gè)表和一個(gè)連接視圖的示例。這個(gè)例子中,當(dāng)我們嘗試刪除一行時(shí),MySQL會(huì)自動(dòng)刪除視圖中相關(guān)的記錄。
然而,問題并不止于此。盡管這種方法可能是可行的,但在涉及多個(gè)表和大量視圖時(shí),操作起來變得更加困難。此外,因?yàn)槲覀儽仨殢?qiáng)制執(zhí)行約束來確保一致性,因此性能開銷可能很高。
在我看來,更可取的方法是手動(dòng)編寫SQL語句來刪除相關(guān)的行。這樣做可能會(huì)更繁瑣,但我們會(huì)更加了解我們的數(shù)據(jù)庫,并且可以避免可能導(dǎo)致問題的自動(dòng)刪除。