MySQL數(shù)據庫中的外鍵約束詳解
來源:易賢網 閱讀:1129 次 日期:2014-08-25 10:41:34
溫馨提示:易賢網小編為您整理了“MySQL數(shù)據庫中的外鍵約束詳解”,方便廣大網友查閱!

[導讀]使用MySQL開發(fā)過數(shù)據庫驅動的小型web應用程序的人都知道,對關系數(shù)據庫的表進行創(chuàng)建、檢索、更新和刪除等操作都是些比較簡單的過程。理論上,只要掌握了最常見的SQL語句的用法,并熟悉您選擇使用的服務器端腳本語言,就足以應付對MySQL表所需的各種操作了,尤其是當您使用了快速MyISAM數(shù)據庫引擎的時候。但是,即使在最簡單

使用MySQL開發(fā)過數(shù)據庫驅動的小型web應用程序的人都知道,對關系數(shù)據庫的表進行創(chuàng)建、檢索、更新和刪除等操作都是些比較簡單的過程。理論上,只要掌握了最常見的SQL語句的用法,并熟悉您選擇使用的服務器端腳本語言,就足以應付對MySQL表所需的各種操作了,尤其是當您使用了快速MyISAM數(shù)據庫引擎的時候。但是,即使在最簡單的情況下,事情也要比我們想象的要復雜得多。下面我們用一個典型的例子進行說明。假設您正在運行一個博客網站,您幾乎天天更新,并且該站點允許訪問者評論您的帖子。

在這種情況下,我們的數(shù)據庫模式至少應該包括兩個MyISAM表,一個用于存放您的博客文章,另一個來處理訪問者的評論。很明顯,這兩個表之間存在一個一對多的關系,所以我們要在第二個表中定義一個外鍵,以便在更新或者刪除數(shù)據行時可以保持數(shù)據庫的完整性。

像上面這樣的應用程序,不僅維護兩個表的完整性是一個嚴峻的挑戰(zhàn),而最大的難點在于我們必須在應用程序級別來維護它們的完整性。這是大部分不要求使用事務的web項目在開發(fā)期間所采取的方法,因為MyISAM表可以提供出色的性能。

當然,這樣做也是有代價的,正如我前面所說的,應用程序必須維護數(shù)據庫的完整性和一致性,這就意味著要實現(xiàn)更復雜的程序設計邏輯來處理各個表之間的關系。雖然可以通過使用抽象層和ORM模塊來簡化數(shù)據庫訪問,但是隨著應用程序所需數(shù)據表的數(shù)量的增加,處理它們所需的邏輯無疑也會隨之變得越發(fā)復雜。

那么,對于MySQL來說,有沒有數(shù)據庫級別的外鍵處理方式來幫助維護數(shù)據庫完整性的呢? 幸運的是,答案是肯定的!MySQL還可以支持InnoDB表,使我們可以通過一種非常簡單的方式來處理外鍵約束。這個特性允許我們可以觸發(fā)器某些動作,諸如更新和刪掉表中的某些數(shù)據行以維護預定義的關系。

凡事有利皆有弊,使用InnoDB表的主要缺點是它們的速度要比MyISAM慢,尤其是在必須查詢許多表的大規(guī)模應用程序中,這一點尤為明顯。好在較新版本MySQL的MyISAM表也已支持外鍵約束。

本文將介紹如何將外鍵約束應用于InnoDB表。此外,我們還將使用一個簡單的基于PHP的MySQL抽象類來創(chuàng)建有關的示例代碼;當然,您也可以使用自己喜歡的其它服務器端語言?,F(xiàn)在,我們開始介紹如何將外鍵約束應用于MySQL。

使用外鍵約束的時機

老實說,在MySQL中使用InnoDB表的時候,不一定非用外鍵約束不可,然而,為了外鍵約束在某些情況下的功用,我們將通過前面提到的例子的代碼進行具體說明。它包括兩個MyISAM表,分別用于存放博客文章和評論。

定義數(shù)據庫模式時,我們要在這兩個表之間建立起一對多的關系,方法是在存放評論的表中創(chuàng)建一個外鍵,以將其中的數(shù)據行(即評論)對應到特定的博客文章。下面是創(chuàng)建示例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;

上面,我們只是定義了兩個MyISAM表,它們構成了博客應用程序的數(shù)據層。如您所見,第一個表名為blogs,它由一些含義很明顯的字段組成,分別用于存放每篇博客文章的ID、標題和內容,最后是作者。第二個表名為comments,用于存放各篇博客文章的有關評論,它將博客文章的ID作為它的外鍵,從而建立起一對多的關系。

迄今為止,我們的工作還算輕松,因為我們只是創(chuàng)建了兩個簡單的MyISAM表。下一步,我們要做的是使用一些記錄來填充這些表,以便進一步演示在第一個表中刪除表項時,應該在另一個表中執(zhí)行那些操作。

更新并維護數(shù)據庫的完整性

前面部分,我們創(chuàng)建了兩個MyISAM表,來充當博客應用程序的數(shù)據層。當然,上面的介紹還很簡單,我們需要做進一步的討論。為此,我們將向這些表中填入一些記錄,方法是使用SQL命令,具體如下所示:

INSERT INTO blogs (id, title, content, author) VALUES (NULL,'Title of the first blog entry', 'Content of the first blog entry', 'Ian')

INSERT INTO comments (id, blog_id, comment, author) VALUES (NULL, 1, 'Commenting first blog entry', 'Susan Norton'), (NULL, 1, 'Commenting first blog entry', 'Rose Wilson')

上面的代碼,實際上模擬了讀者Susan和Rose對我們的第一篇博客作出了評論的情況。假設現(xiàn)在我們要用另一篇文章來更新第一篇博客。當然,這種情況是有可能發(fā)生的。

在這種情況下,為了維護數(shù)據庫的一致性,comments表也必須進行相應的更新,要么通過手工方式更新,或者通過處理數(shù)據層的應用程序進行更新。就本例而言,我們將使用SQL命令來完成更新,具體如下所示: 

UPDATE blogs SET id = 2, title = 'Title of the first blog entry', content = 'Content of the first blog entry', author = 'John Doe' WHERE id = 1

UPDATE comments SET blog_id = 2 WHERE blod_id = 1

更多信息請查看IT技術專欄

更多信息請查看數(shù)據庫
易賢網手機網站地址:MySQL數(shù)據庫中的外鍵約束詳解

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網