MySQL數據庫中的外鍵約束詳解
使用MySQL開發過數據庫驅動的小型web應用程序的人都知道,對關系數據庫的表進行創建、檢索、更新和刪除等操作都是些比較簡單的過程。理論上,只要掌握了最常見的SQL語句的用法,并熟悉您選擇使用的服務器端腳本語言,就足以應付對MySQL表所需的各種操作了,尤其是當您使用了快速MyISAM數據庫引擎的時候。但是,即使在最簡單的情況下,事情也要比我們想象的要復雜得多。下面我們用一個典型的例子進行說明。假設您正在運行一個博客網站,您幾乎天天更新,并且該站點允許訪問者評論您的帖子。
在這種情況下,我們的數據庫模式至少應該包括兩個MyISAM表,一個用于存放您的博客文章,另一個來處理訪問者的評論。很明顯,這兩個表之間存在一個一對多的關系,所以我們要在第二個表中定義一個外鍵,以便在更新或者刪除數據行時可以保持數據庫的完整性。
像上面這樣的應用程序,不僅維護兩個表的完整性是一個嚴峻的挑戰,而最大的難點在于我們必須在應用程序級別來維護它們的完整性。這是大部分不要求使用事務的web項目在開發期間所采取的方法,因為MyISAM表可以提供出色的性能。
當然,這樣做也是有代價的,正如我前面所說的,應用程序必須維護數據庫的完整性和一致性,這就意味著要實現更復雜的程序設計邏輯來處理各個表之間的關系。雖然可以通過使用抽象層和ORM模塊來簡化數據庫訪問,但是隨著應用程序所需數據表的數量的增加,處理它們所需的邏輯無疑也會隨之變得越發復雜。
那么,對于MySQL來說,有沒有數據庫級別的外鍵處理方式來幫助維護數據庫完整性的呢? 幸運的是,答案是肯定的!MySQL還可以支持InnoDB表,使我們可以通過一種非常簡單的方式來處理外鍵約束。這個特性允許我們可以觸發器某些動作,諸如更新和刪掉表中的某些數據行以維護預定義的關系。
凡事有利皆有弊,使用InnoDB表的主要缺點是它們的速度要比MyISAM慢,尤其是在必須查詢許多表的大規模應用程序中,這一點尤為明顯。好在較新版本MySQL的MyISAM表也已支持外鍵約束。
本文將介紹如何將外鍵約束應用于InnoDB表。此外,我們還將使用一個簡單的基于PHP的MySQL抽象類來創建有關的示例代碼;當然,您也可以使用自己喜歡的其它服務器端語言。現在,我們開始介紹如何將外鍵約束應用于MySQL。
使用外鍵約束的時機
老實說,在MySQL中使用InnoDB表的時候,不一定非用外鍵約束不可,然而,為了外鍵約束在某些情況下的功用,我們將通過前面提到的例子的代碼進行具體說明。它包括兩個MyISAM表,分別用于存放博客文章和評論。
定義數據庫模式時,我們要在這兩個表之間建立起一對多的關系,方法是在存放評論的表中創建一個外鍵,以將其中的數據行(即評論)對應到特定的博客文章。下面是創建示例MyISAM表的基本SQL代碼:
DROP TABLE IF EXISTS `test`.`blogs`;
CREATE TABLE `test`.`blogs` (
`id` INT(10) UNSIGNED AUTO_INCREMENT,
`title` TEXT,
`content` TEXT,
`author` VARCHAR(45) DEFAULT NULL,
PRIROSE KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
DROP TABLE IF EXISTS `test`.`comments`;
CREATE TABLE `test`.`comments` (
`id` INT(10) UNSIGNED AUTO_INCREMENT,
`blog_id` INT(10) UNSIGNED DEFAULT NULL,
`comment` TEXT,
`author` VARCHAR(45) DEFAULT NULL,
PRIROSE KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
關鍵字:數據庫、服務器、MySQL
新文章:
- CentOS7下圖形配置網絡的方法
- CentOS 7如何添加刪除用戶
- 如何解決centos7雙系統后丟失windows啟動項
- CentOS單網卡如何批量添加不同IP段
- CentOS下iconv命令的介紹
- Centos7 SSH密鑰登陸及密碼密鑰雙重驗證詳解
- CentOS 7.1添加刪除用戶的方法
- CentOS查找/掃描局域網打印機IP講解
- CentOS7使用hostapd實現無AP模式的詳解
- su命令不能切換root的解決方法
- 解決VMware下CentOS7網絡重啟出錯
- 解決Centos7雙系統后丟失windows啟動項
- CentOS下如何避免文件覆蓋
- CentOS7和CentOS6系統有什么不同呢
- Centos 6.6默認iptable規則詳解