[精讚] [會員登入]
2564

[Mysql/Mariadb] 利用phpMyAdmin 建立關聯式資料表

利用phpMyAdmin 建立關聯式資料表

此文完整連結 http://n.sfs.tw/10850

複製連結 [Mysql/Mariadb] 利用phpMyAdmin 建立關聯式資料表@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2017-03-03 11:41:16 最後編修
2017-03-03 11:39:44 By 瘦河馬
 

想用 phpMyAdmin 建立關聯式資料表一直不得其門而入,以前我就有學到 foreign key 的觀念,但是奇怪,console怎麼設都錯誤,而 phpMyAdmin 上也找不到選項,後來只好用程式來解決關聯的問題,這也是低等級程設師常做的事,繞過問題而不去花時間解決問題。至於什麼是關聯式資料庫,網路上很多理論說明,不再贅言。

後來經過瑩光兄一點,才恍然大悟,原來資料表的引擎要用 innoDB 才能建立關聯式資料表,怪不得我以前怎麼試都失敗 + +。以下是建立關聯式資料表的簡單範例及說明。

一、建立一個資料庫,例如 hades,在裡面建立兩個表。

這個是主要表,例如我現在建立一個身體部位的資料表,裡面的主鍵是 bID 格式 smallint(6) ,只要是具有唯一鍵性質的欄位,就可以被當成是 foregin key,例如主鍵、唯一鍵,而子表中的欄位只有主鍵、唯一鍵或是索引鍵可以和 foregin key建立關聯。

-- 資料表格式: `bodyparts`
--

CREATE TABLE IF NOT EXISTS `bodyparts` (
  `bID` smallint(6) NOT NULL auto_increment,
  `bname` varchar(24) collate utf8_bin NOT NULL,
  PRIMARY KEY  (`bID`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COLLATE=utf8_bin ROW_FORMAT=DYNAMIC AUTO_INCREMENT=7 ;
 

這是子表,他要和主表 `bodyparts` 建立關聯。如此當主表該筆foreign key 刪除時,子表有關聯到的欄位也要一併刪除,或是主表修改bID時,子表有關聯到的欄位`syndrome`.`bID`= `bodyparts`.`bID` 也要一併修改,以免久而久之遺留很多找不到關聯的垃圾記錄或是資料不同步。

--
-- 資料表格式: `syndrome`
--

CREATE TABLE IF NOT EXISTS `syndrome` (
  `sID` smallint(9) NOT NULL auto_increment,
  ...
  `bID` smallint(9) NOT NULL,
  PRIMARY KEY  (`sID`),
  KEY `bID` (`bID`)

) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COLLATE=utf8_bin ROW_FORMAT=DYNAMIC AUTO_INCREMENT=3 ;

二、在子資料表 `syndrome`建立關連到主表

ALTER TABLE `syndrome`
  ADD CONSTRAINT `syndrome_ibfk_1` FOREIGN KEY (`bID`) REFERENCES `bodyparts` (`bID`) ON DELETE CASCADE ON UPDATE CASCADE;

觀察重點:子表上 bID 並不一定要唯一鍵,而『關聯檢視』的連結要innoDB引擎才會出現

點選「關聯檢視」後,將bID的foregin key指到: `bodyparts`(`bID`)。

後面兩個是當主表的 `bodyparts`(`bID`) 發生刪除或修改時,要採取的行為。其中有下列選項:

CASCADE  階層狀異動:主表刪子表就刪;主表修子表就修。
SET NULL 主表想要更動時(刪或修),子表將該欄位設為空值
NO ACTION 什麼都不做,那還建關聯幹嘛?
RESTRICT 這個玩意就是限制,當主表想要更動時(刪或修),子表有設為 RESTRICT,主表的更動會受到限制,產生錯誤

感謝

這篇文章的產生,得感謝外埔國小陳瑩光師的指導


原文 2009-12-04 23:58:28

你可能感興趣的文章

[Mysql] 使用索引來加速搜尋 只要是常常用到搜索條件的欄位,就應該把它設成索引鍵,有無設定的速度差可能會好幾倍

[Mysql/MariaDB] 表格的引擎 (engine):查看及修改 MySQL表格引擎預設為 MyISAM,但在4.0以上的mysql 其實支援不只一種引擎,各有優缺點,這篇介紹引擎的操作。

兩次使用InnoDB的慘痛經驗 Mysql 的Innodb引擎雖然好用,但是我得說說我兩次的慘痛經驗,這讓我考慮以後可能不會再使用innodb了

[mysqldump] Mysqldump時出現記憶體錯誤Out of memory 當進行 mysqldump 時出現 Out of memory (Needed xxxxx bytes) 的錯誤,該如何處理?

[MYSQL] 把SELECT的結果UPDATE到表中 Mysql update select 出來的結果,一次完成

[MYSQL] 查看資料表狀態 要看資料表的狀態,不是結構喔,以前我都會用 procedure analyse(): SELECT `colname`

[Mysql/Mariadb] GROUP_CONCAT 函數 MySQL 中和 group by 一起用的函式,如果我們要算數值的總和或平均,可以使用 sum() 或 avg() 。但是我們如果要在 group by 中把字串「黏起來」,不是使用 concat(

[MYSQL] 設定字串欄位的預設值 新增表格的時候,字串欄位給予預設空值;數字欄位給預設數值;日期欄位給空值。

[Mysql/MariaDB] 查看資料庫所占空間 查看資料庫在磁碟中所占空間

[Mysql/Mariadb] Left Join 和 Right Join 合併表單 SQL語法中的 Left Join 和 Right Join 很常用,但是我常會忘記,所以寫下來備忘。

我有話要說


限制:留言最高字數1000字,超過部分會被截掉。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

[jQuery] textarea 的取值和給值 HTML 的 TEXTAREA 標籤若要用 jquery 取值,不能使用 .text() 或 .html() ,使用 .

談借錢 人借錢時手心向上頭向下,人還錢時手心向下頭向上

TFTP Server 安裝及使用 讓設備的網路設定檔或是韌體經由TFTP拷備出來,操作的方法

一個邏輯的錯誤刪了全部檔案的經驗 今天本來想做一件很簡單的事,但卻足足浪費我多一倍的時間,再加上刪掉我全部的檔案,原因只是因為我自己的邏輯錯誤。

APACHE的記錄檔格式 LogFormat 語法 在APACHE中有定義一些記錄的語法模版 在 /etc/httpd/conf/httpd.conf 中: LogForm