看板 Knuckles_note
作者 標題 [MySQL] 在phpMyAdmin 設定 foreign key
時間 2010年01月10日 Sun. PM 04:27:05
剛剛偶然得知資料庫有種叫 foreign key 的東西
可以將不同資料表的東西「關連」起來
舉例來說
像這個站的每個板,和每篇板裡的每篇文章
是分別用兩個資料表來儲存的
資料表 board 欄位: id name ...
值: 1 test ...
2 DISP_BBS ...
資料表 text 欄位: id bi author title ...
值: 1 1 kk 測試 ...
2 1 Knuckles 測試一下 ...
3 2 abc 有Bug ...
4 2 xyz123 問題 ...
所有看板的文章都是存在 text 裡面,以欄位 bi 來分別是哪個看板的
如果今天我刪掉了 board 裡的看板 test
那個看板裡的文章還是存在於 text 裡造成空間的浪費
除非我程式裡再加上刪除 bi=1 的文章
但如果我把 text.bi 設了 foreign key 參考到 board.id
那麼只要我在board刪除了某個板,則在text中相對應的文章就會自動被刪除掉了
但是在 phpMyAdmin 中卻找不到設定 foreign key 的選項...
Google了一下找到這篇文章 phpMyAdmin 設定 mysql foreign key
原來要使用 foreign key,兩個資料表的儲存引擎一定要使用 InnoDB
如果沒有 InnoDB 這個選項,修改mysql設定檔: my.ini,將skip-innodb加#號註解,即#skip-innodb
重新啟動 mysql
設定好後在資料表結構的下面就會出現「關聯檢視」的選項
點一下後就會出現 foreign key 的設定畫面
將 bi 的參考設定為 board.id (注意兩個欄位的型態要相同)
ON DELETE 設定為 CASCADE,代表board某個row被刪掉時,text.bi=board.id的row也要跟著被刪除
另外也有 ON UPDATE 可以設定當 board.id 有更改時,text.bi要不要跟著更改
除了 CASCADE 外,也有 SET NULL, NO ACTION, RESTRICT 可以選
如果沒有設對應動作的話,則被參考的row會無法刪除
注意:
‧ 被連結的key必需設為主鍵或索引鍵
‧ 兩個相連結的資料型態必需相同
‧ 不能有不存在於被連結的資料中的值 (text.bi的值中有board.id中不存在的值)
- 使用left join刪除多餘的值:
DELETE text FROM text LEFT JOIN board ON text.bi = board.id where board.id is NULL
--
※ 來源: DISP BBS (http://disp.disp.cc)
※ 作者: Knuckles 來自: 114.43.123.194 時間: 2010-01-10 16:27:05
※ 編輯: Knuckles 時間: 2013-11-17 18:13:27
※ 看板: KnucklesNote 文章推薦值: 0 目前人氣: 0 累積人氣: 20982
回列表(←)
分享