国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

快速理解MySQL中主鍵與外鍵的實(shí)例教程

2024-07-24 13:08:14
字體:
供稿:網(wǎng)友

這篇文章主要介紹了MySQL中主鍵與外鍵的區(qū)別和聯(lián)系,是MySQL入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下

主鍵與外鍵的關(guān)系,通俗點(diǎn)兒講,我現(xiàn)在有一個(gè)論壇,有兩張表,一張是主貼 thread,一張是回帖 reply

先說說主鍵,主鍵是表里面唯一識(shí)別記錄的字段,一般是帖子id,體現(xiàn)在訪問的時(shí)候,例如是

thread.php?id=1 表示我要訪問的是帖子id是1 的帖子~

再來說說外鍵,當(dāng)我們刪除某個(gè)帖子的時(shí)候,需要執(zhí)行另一個(gè)操作,就是刪除所有回帖,如果正常情況下,我們需要執(zhí)行兩次delete操作(thread和 reply),這時(shí)候如果存在外鍵,例如,在reply 表里面建立一個(gè)指向thread表的主鍵(id)的外鍵(這個(gè)外鍵綁的字段,必須是對應(yīng)帖子的id),并指定響應(yīng) delete ,那你在刪除 thread 的時(shí)候,mysql 自己會(huì)幫你把 reply 表中這個(gè)帖子的回復(fù)都刪掉,而不需要你手動(dòng)再去執(zhí)行一次reply表的delete操作~

至于兩者之間的關(guān)系,在剛才的例子中,reply 表的外鍵,指向的就是 thread 表的主鍵~~

搞個(gè)例子,簡單演示一下使用,做dage和xiaodi兩個(gè)表,大哥表是主鍵,小弟表是外鍵:

建表:

 

 
  1. CREATE TABLE `dage` ( 
  2. `id` int(11) NOT NULL auto_increment, 
  3. `name` varchar(32) default ''
  4. PRIMARY KEY (`id`) 
  5. ) ENGINE=InnoDB DEFAULT CHARSET=latin1; 
  6.  
  7. CREATE TABLE `xiaodi` ( 
  8. `id` int(11) NOT NULL auto_increment, 
  9. `dage_id` int(11) default NULL, 
  10. `name` varchar(32) default ''
  11. PRIMARY KEY (`id`), 
  12. KEY `dage_id` (`dage_id`), 
  13. CONSTRAINT `xiaodi_ibfk_1` FOREIGN KEY (`dage_id`) REFERENCES `dage` (`id`) 
  14. ) ENGINE=InnoDB DEFAULT CHARSET=latin1; 

插入個(gè)大哥:

 

 
  1. mysql> insert into dage(name) values('銅鑼灣'); 

 

 
  1. Query OK, 1 row affected (0.01 sec) 

 

 
  1. mysql> select * from dage; 

 

 
  1. +----+--------+ 
  2. | id | name | 
  3. +----+--------+ 
  4. | 1 | 銅鑼灣 | 
  5. +----+--------+ 
  6. 1 row in set (0.00 sec) 

插入個(gè)小弟:

 

 
  1. mysql> insert into xiaodi(dage_id,name) values(1,'銅鑼灣_小弟A'); 

 

 
  1. Query OK, 1 row affected (0.02 sec) 

 

 
  1. mysql> select * from xiaodi; 

 

 
  1. +----+---------+--------------+ 
  2. | id | dage_id | name | 
  3. +----+---------+--------------+ 
  4. | 1 | 1 | 銅鑼灣_小弟A | 
  5. +----+---------+--------------+ 

把大哥刪除:

 

 
  1. mysql> delete from dage where id=1; 

 

 
  1. ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`bstar/xiaodi`, CONSTRAINT `xiaodi_ibfk_1` FOREIGN KEY (`dage_id`) REFERENCES `dage` (`id`)) 

提示:不行呀,有約束的,大哥下面還有小弟,可不能扔下我們不管呀!

插入一個(gè)新的小弟:

 

 
  1. mysql> insert into xiaodi(dage_id,name) values(2,'旺角_小弟A'); 

 

 
  1. 2ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`bstar/xiaodi`, CONSTRAINT `xiaodi_ibfk_1` FOREIGN KEY (`dage_id`) REFERENCES `dage` (`id`)) 

提示:小子,想造反呀!你還沒大哥呢!

把外鍵約束增加事件觸發(fā)限制:

 

 
  1. mysql> show create table xiaodi; 
  2. <p>CONSTRAINT `xiaodi_ibfk_1` FOREIGN KEY (`dage_id`) REFERENCES `dage` (`id`)</p><p>mysql> alter table xiaodi drop foreign key xiaodi_ibfk_1; <br></p> 

 

 
  1. Query OK, 1 row affected (0.04 sec) 
  2. Records: 1 Duplicates: 0 Warnings:  

 

 
  1. mysql> alter table xiaodi add foreign key(dage_id) references dage(id) on delete cascade on update cascade; 

 

 
  1. Query OK, 1 row affected (0.04 sec) 
  2. Records: 1 Duplicates: 0 Warnings: 0 

再次試著把大哥刪了:

 

  1. mysql> delete from dage where id=1; 

 

  
  1. Query OK, 1 row affected (0.01 sec) 

 

 
  1. mysql> select * from dage; 

 

 
  1. Empty set (0.01 sec) 

 

 
  1. mysql> select * from xiaodi; 

 

 
  1. Empty set (0.00 sec) 

得,這回對應(yīng)的小弟也沒了,沒辦法,誰讓你跟我on delete cascade了呢!

例子說明的應(yīng)該蠻清楚了吧,其他功能對應(yīng)手冊自己實(shí)踐吧!:-)


注:相關(guān)教程知識(shí)閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 潜江市| 临湘市| 泰来县| 泽州县| 沁源县| 辽宁省| 剑川县| 池州市| 綦江县| 乡宁县| 闵行区| 调兵山市| 辉县市| 乌拉特后旗| 志丹县| 四会市| 开原市| 革吉县| 潍坊市| 绥阳县| 唐海县| 兴化市| 平陆县| 长岛县| 竹山县| 始兴县| 临沧市| 赤壁市| 利川市| 修水县| 抚松县| 岗巴县| 政和县| 宣恩县| 榆林市| 东平县| 拉孜县| 汉中市| 伊通| 新乐市| 如东县|