使用Navicat for MySQL添加外鍵約束


轉載:http://blog.csdn.net/u013215018/article/details/54981216

 

現在有兩個表一張是Roles表(角色表),一張是RoleUser表(用戶角色)

現在我想把RoleUser表中的RoleID屬性設置為外鍵,關聯Roles表中的RoleID屬性。

操作步驟:

第一步:

  

第二步:

一共有七列。簡單介紹一下這幾列的意思:

   “名”:  可以不填,你一會保存成功系統會自動生成。

   “欄位”:就是你要把哪個鍵設置為外鍵。這里選擇‘RoleID’

   “參考數據庫”: 外鍵關聯的數據庫。

   “引用表”: 關聯的表 這里是Roles表

   “外欄位名”:關聯的的字段,這里是RoleID

   “刪除時":就是刪除的時候選擇的動作。這里我的選擇是setNull,意思就是當關聯的表刪除以后,RoleUser->RoleID字段會設置為null。

   “ 更新時”:就是更新的時候選擇的動作。這里我的選擇是CASCADE,意思就是當關聯的表更新以后,RoleUser->RoleID字段會設置為級聯更新。

 

 

 

 

關系型數據庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能唯一標識一條記錄,該屬性組就可以成為一個主鍵。

比如:

學生表(學號,姓名,性別,班級)

其中每個學生的學號是唯一的,學號就是一個主鍵;

課程表(課程編號,課程名,學分)

其中課程編號是唯一的,課程編號就是一個主鍵;

成績表(學號,課程號,成績)

成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以,學號和課程號的屬性組是一個主鍵。

 

成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,並且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外鍵;同理,成績表中的課程號是課程表的外鍵。

 

定義主鍵和外鍵主要是為了維護關系數據庫的完整性,總結一下:

一、主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份正號,姓名,年齡。身份證號是唯一能確定你這個人的,其他都可能有重復,所以,身份證號是主鍵。

外鍵用於與另一張表的關聯。是能確定另一張表記錄的字段,用於保持數據的一致性。比如,A表中的一個字段,是B表的主鍵,那他就可以是A表的外鍵。

 

二、主鍵、外鍵和索引的區別

 

定義:

主鍵--唯一標識一條記錄,不能有重復的,不允許為空

外鍵--表的外鍵是另一表的主鍵, 外鍵可以有重復的, 可以是空值

索引--該字段沒有重復值,但可以有一個空值

 

作用:

主鍵--用來保證數據完整性

外鍵--用來和其他表建立聯系用的

索引--是提高查詢排序的速度


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM