亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

MySQL數據庫開發中的外鍵與參照完整性

添加時間:2013-1-19 17:54:09  添加: 思海網絡 
參照完整性(Referential integrity)是數據庫設計中一個重要的概念。在系統不同的列表中,當數據庫所有參照合法或非合法關聯時都會涉及到參照完整性。當參照完整性存在時,任何與不存在記錄的關聯將變得無效化,由此可防止用戶出現各種錯誤,從而提供更為準確和實用的數據庫。

  參照完整性通常通過外鍵(foreign key)的使用而被廣泛應用。長久以來,流行工具開源RDBMS MySQL并沒有支持外鍵,原因是這種支持將會降低RDBMS的速度和性能。然而,由于很多用戶對參照完整性的優點倍感興趣,最近MySQL的不同版本都通過新InnoDB列表引擎支持外鍵。由此,在數據庫組成的列表中保持參照完整性將變得非常簡單。

  為了建立兩個MySQL表之間的一個外鍵關系,必須滿足以下三種情況:

  • 兩個表必須是InnoDB表類型。
  • 使用在外鍵關系的域必須為索引型(Index)。
  • 使用在外鍵關系的域必須與數據類型相似。

  例子是理解以上要點的最好方法。如表A所示,建立兩個表,其中一個列出動物種類及相應的代碼(表名為:species),另一表列出動物園中的動物(表名為:zoo)。現在,我們想通過species關聯這兩個表,所以我們只需要接受和保存zoo表中包含species表中的合法動物的入口到數據庫中。

  表A

mysql> CREATE TABLE species (id TINYINT NOT NULL AUTO_INCREMENT, name VARCHAR(50) NOT NULL, PRIMARY KEY(id)) ENGINE=INNODB;Query OK, 0 rows affected (0.11 sec)mysql> INSERT INTO species VALUES (1, 'orangutan'), (2, 'elephant'), (3, 'hippopotamus'), (4, 'yak');Query OK, 4 rows affected (0.06 sec)Records: 4 Duplicates: 0 Warnings: 0mysql> CREATE TABLE zoo (id INT(4) NOT NULL, name VARCHAR(50) NOT NULL, FK_species TINYINT(4) NOT NULL, INDEX (FK_species), FOREIGN KEY (FK_species) REFERENCES species (id), PRIMARY KEY(id)) ENGINE=INNODB;
注意:對于非InnoDB表, FOREIGN KEY 語句將被忽略。

  現在,fieldszoo.speciesspecies.id 之間存在一個外鍵關系。只有相應的zoo.speciespecies.idfield的一個值相匹配,動物表中的入口才可被訪問。以下的輸出即演示了當你想輸入一個Harry Hippopotamus記錄,而使用到不合法的species代碼:

mysql> INSERT INTO zoo VALUES (1, 'Harry', 5);
ERROR 1216 (23000): Cannot add or update a child row: a foreign key constraint fails

這里,MySQL核查species表以查看species代碼是否存在,如果發現不存在,就拒絕該記錄。當你輸入正確代碼的,可以與以上做比較。

mysql> INSERT INTO zoo VALUES (1, 'Harry', 3);
Query OK, 1 row affected (0.06 sec)

  這里,MySQL核查species表以查看species代碼是否存在,當發現存在,允許記錄保存在zoo表中。

  為了刪除一個外鍵關系,首先使用SHOW CREATE TABLE找出InnoDB的內部標簽,如表B所示:

表 B

+-------+---------------------------------------------------+
| Table | Create Table |
+-------+---------------------------------------------------+
| zoo | CREATE TABLE `zoo` (
`id` int(4) NOT NULL default '0',
`name` varchar(50) NOT NULL default '',
`FK_species` tinyint(4) NOT NULL default '0',
KEY `FK_species` (`FK_species`),
CONSTRAINT `zoo_ibfk_1` FOREIGN KEY (`FK_species`)
REFERENCES `species` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
+-------+----------------------------------------------------+

  然后使用帶有DROP FOREIGN KEY 語句的ALTER TABLE命令,如以下:

mysql> ALTER TABLE zoo DROP FOREIGN KEY zoo_ibfk_1;
Query OK, 1 row affected (0.11 sec)
Records: 1 Duplicates: 0 Warnings: 0

  為了將一個外鍵添加到一個現成的表中,使用ADD FOREIGN KEY ALTER TABLE語句指定合適的域作為一個外鍵:

mysql> ALTER TABLE zoo ADD FOREIGN KEY (FK_species) REFERENCES species (id);
Query OK, 1 rows affected (0.11 sec)
Records: 1 Duplicates: 0 Warnings: 0

  如以上例子解釋的,外鍵在捉摸數據入口錯誤上起著重要的作用,由此可建立更為強健更加集成的數據庫。另一方面值得提到的是,執行外鍵核實是內部資料處理的過程,且不同表之間指定復雜的內部關系可以導致數據庫的性能下降。所以,在參照完整性與性能考慮之間找到平衡點相當重要,而使用外鍵就是能夠確保性能與穩健之間的最優結合。

  我期望本期的有關外鍵的介紹對你有所好處,你將會在下回的MySQL數據庫設計中感受到外鍵的好處。編程快樂!

關鍵字:MySQL、數據庫

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站