MySQL資料庫中的外鍵約束詳解

來源:互聯網
上載者:User

  使用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;

1 2 3 下一頁 >全文閱讀 提示:試試"← →"鍵,翻頁更方便哦!

相關文章

Alibaba Cloud 10 Year Anniversary

With You, We are Shaping a Digital World, 2009-2019

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。