資料庫表的外鍵
㈠ 資料庫中什麼是主鍵,什麼是外鍵
主鍵(Primary key): 也稱為主碼或主關鍵字,用於惟一地確定一個元組的屬性或屬性組(復合主碼)。每個關系都有一個並且只有一個主碼。
外鍵(Foreign Key):也稱為外碼或外部關鍵字。如果一個屬性集不是所在關系的關鍵字,但是是其他關系的關鍵字,則該屬性集稱為外部關鍵字。
在關系資料庫中可以通過外鍵使兩個關系關聯,這種聯系通常是一對多(1:n)的,其中主(父)關系(1方)稱為被參照關系,從(子)關系(n方)稱為參照關系。
(1)資料庫表的外鍵擴展閱讀:
資料庫主鍵作用:
1、保證實體的完整性
2、加快資料庫的操作速度
3、在表中添加新記錄時,DBMS會自動檢查新記錄的主鍵值,不允許該值與其他記錄的主鍵值重復。
4、DBMS自動按主鍵值的順序顯示表中的記錄。如果沒有定義主鍵,則按輸入記錄的順序顯示表中的記錄。
在有些資料庫中,雖然主鍵不是必需的,但最好為每個表都設置一個主鍵,不管是單主鍵還是復合主鍵。它存在代表著表結構的完整性,表的記錄必須得有唯一區分的欄位,主鍵主要是用於其他表的外鍵關聯,以及本記錄的修改與刪除。
㈡ 資料庫外鍵約束
資料庫外鍵約束:這個是實現表與表之間的約束,從表的欄位值必須在主表中。存在外鍵約束畢竟是一個約束,只是保證數據完整性的一個手段。
㈢ 什麼是外鍵
外鍵就是指另外表中的主鍵 。
保持數據一致性,完整性,主要目的是控制存儲在外鍵表中的數據。 使兩張表形成關聯,外鍵只能引用外表中的列的值或使用空值。
使用原則:
1、 為關聯欄位創建外鍵。
2、 所有的鍵都必須唯一。
3、避免使用復合鍵。
4、外鍵總是關聯唯一的鍵欄位。
㈣ 如何設置資料庫中的外鍵
外鍵的設計初衷是為了在資料庫端保證對邏輯上相關聯的表數據在操作上的一致性與完整性。
優點:
精簡關聯數據,減少數據冗餘
避免後期對大量冗餘處理的額外運維操作。
降低應用代碼復雜性,減少了額外的異常處理
相關數據管理全由資料庫端處理。
增加文檔的可讀性
特別是在表設計開始,繪制 ER 圖的時候,邏輯簡單明了,可讀性非常強。
性能壓力
外鍵一般會存在級聯功能,級聯更新,級聯刪除等等。在海量數據場景,造成很大的性能壓力。比如插入一條新記錄,如果插入記錄的表有 10 個外鍵,那勢必要對關聯的 10 張表逐一檢查插入的記錄是否合理,延誤了正常插入的記錄時間。並且父表的更新會連帶子表加上相關的鎖。
其他功能的靈活性不佳
比如,表結構的更新等。
缺點:
㈤ 資料庫外鍵問題
要你資料庫設計合理,使用合法,可以不需要外鍵
1
外鍵是將B表的某列和A表的主鍵連接起來。
A的主鍵是id,那麼就是它了。
2
select
a.username,a.userpwd,b.gold
from
a,b
where
a.id=b.gold;
3
同時更新或者操作兩個表(比如通過A的值來檢索B的值)?
通過A的值來檢索B的值
就如上面所說一個sql語句就可以了。
同時更新的話你可以用觸發器。也可以用存儲過程。
在存儲過程中直接對兩個表進行操作就能達到你的目的。
你的問題還很籠統。如果不明白最好就一個具體問題來提問。
㈥ 資料庫中外鍵的概念及作用。
表A中有欄位(如身份證號)做了主鍵,表B中也有這個欄位(身份證號),這里的身份證號一定來自表A同樣欄位里的內容,那麼表B的這個欄位就叫表A欄位的外鍵,也就是兩個表以身份證號這個欄位建立了聯系。
表A中身份證號欄位裡面的身份證號一定是唯一的,不能有重復,而表B裡面的同一個身份證號可以出現多次。這稱為表A身份證號欄位與表B身份證號欄位建立了一對多的關系。
㈦ 資料庫語句怎麼加外鍵
1、以具有 DBA 許可權的用戶身份連接到資料庫,執行 ALTER TABLE 語句,將表定義更新為包括外鍵定義。創建一個名為 Skills 的表,其中包含潛在技能列表,然後創建一個與 Skills 表具有外鍵關系、名為 EmployeeSkills 的表。
㈧ 資料庫之主鍵外鍵
1,主鍵約束 (table的唯一標識)
能夠作為主鍵列的特點:該列不能為空,不能有重復值出現
創建表時指定主鍵的兩種方式:
CREATE TABLE stu(
sid CHAR(6) PRIMATY KEY,
sname VARCHAR(20),
age INT,
gender VARCHER(10)
);
指定sid列為主鍵列
CREATE TABLE stu(
sid CHAR(6),
sname VARCHAR(20),
age INT,
gender VARCHER(10),
PRIMARY KEY(sid)
);
指定sid列為主鍵列
修改表時指定主鍵:ALTER TABLE stu ADD PRIMATY KEY(sid);
刪除主鍵:ALTER TABLE stu DROP PRIMARY KEY;
2,主鍵自增長
因為主鍵列的特性是:必須唯一,不能為空,所以我們通常會指定主鍵為整形,然後設置其自動增長
創建表時指定主鍵自增長:
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20),
age INT,
gender VARCHAR(10)
);
修改表時設置主鍵自增長:ALTER TABLE stu
3,非空約束
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20) NOT NULL,
age INT,
gender VARCHAR(10)
);
對sname列設置了非空約束
4,唯一約束
某些列不能設置重復的值,所以可以對列添加唯一約束
CREATE TABLE stu(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR(20) NOT NULL UNIQUE,
age INT,
gender VARCHAR(10)
);
6,外鍵約束
外鍵特點:外鍵必須是另一個表的主鍵的值(外鍵要引用主鍵!),外鍵可以重復,外鍵可以為空,一張表可以有多個外鍵!
CREATE TABLE dept( //部門表
deptno INT PRIMARY KEY AUTO_INCREMENT,
deptname CHAR(20)
);
INSERT INTO dept VALUES(10,『研發部』);
INSERT INTO dept VALUES(20,『人力部』);
INSERT INTO dept VALUES(30,『財務部』);
CREATE TABLE emp( //員工表
empno INT PRIMARY KEY AUTO_INCREMENT,
ename VARCHAR(50),
dno INT, //員工所屬部門(外鍵),
CONSTRAINT fk_emp_dept FOREIGN KEY(dno) REFERENCES dept(deptno)
);
INSERT INTO emp(empno,ename) VALUES(NULL,『張三』),//外鍵可以不傳入值
INSERT INTO emp(empno,ename) VALUES(NULL,『李四』,10),//外鍵可以重復
INSERT INTO emp(empno,ename) VALUES(NULL,『王五』,10),
INSERT INTO emp(empno,ename) VALUES(NULL,『趙六』,80),//dept表沒有主鍵值為80的記錄,sql客戶端編譯報錯
7,一對一關系模型
創建老公表
CREATE TABLE hashand(
hid INT PRIMARY KEY AUTO_INCREMENT,
hname VARCHAR(50),
);
INSERT INTO hashand VALUES(NULL,『劉備』);
INSERT INTO hashand VALUES(NULL,『關羽』);
INSERT INTO hashand VALUES(NULL,『張飛』);
SELECT * FROM hashand
//創建老婆表
CREATE TABLE wife(
wid INT PRIMARY KEY AUTO_INCREMENT,
wname VARCHAR(50),
CONSTRAINT fk_wife_hashand FOREIGN KEY(wid) REFERENCES hashand(hid)
)
/**
wid:
1,非空
2,唯一
3,引用hid
*/
INSERT INTO wife VALUES(1,『楊貴妃』);
INSERT INTO wife VALUES(2,『妲己』);
INSERT INTO wife VALUES(3,『褒姒』);
SELECT * FROM wife;
對於一對一關系模型從表的主鍵即是外鍵,例如老公和老婆的關系模型,一個老公只能有一個老婆,一個老婆只能有一個老公
對於一對多關系模型主表的主鍵即是從表的外鍵,例如訂單和用戶的關系模型,一個用戶可以下單多次,對應多個訂單,而一個訂單只能屬於一個用戶
對於多對多關系模型沒有主表和從表之分,需要建立第三張表來記錄這兩張表的外鍵,建立兩個外鍵,分別引用這兩張表的主鍵
8,多對多關系模型
在表中簡歷多對多關系需要使用中間表,即需要三張表,在中間表中使用兩個外鍵,分別引用其他兩個表的主鍵,例如學生和老師的關系模型,一個老師可以有多個學生,一個學生可以有多個老師
CREATE TABLE student(
sid INT PRIMARY KEY AUTO_INCREMENT,
sname CHAR(40)
);
CREATE TABLE teacher(
tid INT PRIMARY KEY AUTO_INCREMENT,
tname CHAR(40)
);
CREATE TABLE stu_tea(
sid INT,
tid INT,
ADD CONSTRAINT fk_stu_tea_sid FOREIGN KEY(sid) REFERENCES student(sid),
ADD CONSTRAINT fk_stu_tea_tid FOREIGN KEY(tid) REFERENCES teacher(tid)
);
INSERT INTO student VALUES(NULL,『劉德華』);
INSERT INTO student VALUES(NULL,『梁朝偉』);
INSERT INTO student VALUES(NULL,『黃日華』);
INSERT INTO student VALUES(NULL,『苗僑偉』);
INSERT INTO student VALUES(NULL,『湯鎮業』);
INSERT INTO teacher VALUES(NULL,『崔老師』);
INSERT INTO teacher VALUES(NULL,『劉老師』);
INSERT INTO teacher VALUES(NULL,『石老師』);
SELECT * FROM student;
SELECT * FROM teacher;
INSERT INTO stu_tea VALUES(1,1); //劉德華是崔老師的學生
INSERT INTO stu_tea VALUES(2,1); //梁朝偉是崔老師的學生
INSERT INTO stu_tea VALUES(3,1);//黃日華是崔老師的學生
INSERT INTO stu_tea VALUES(4,1);//苗僑偉是崔老師的學生
INSERT INTO stu_tea VALUES(5,1);//湯鎮業是崔老師的學生
INSERT INTO stu_tea VALUES(2,2);//梁朝偉是劉老師的學生
INSERT INTO stu_tea VALUES(3,2);//黃日華是劉老師的學生
INSERT INTO stu_tea VALUES(4,2);//苗僑偉是劉老師的學生
INSERT INTO stu_tea VALUES(3,3);//黃日華是石老師的學生
INSERT INTO stu_tea VALUES(5,3);//湯鎮業是劉老師的學生
SELECT * FROM stu_tea;
這時在stu_tea這個中間表中的每條記錄都是來說明student表和teacher表的關系的
例如在stu_tea表中的記錄:sid為1001,tid為2001,這說明編號為1001的學生有一個編號為2001的老師
sid tid
1001 2001 //編號為1001的學生有一個編號為2001的老師
1001 2002 //編號為1001的學生有一個編號為2002的老師
1001 2003 //編號為1001的學生有一個編號為2003的老師
1002 2001 //編號為2001的老師有一個編號為1002的學生
1002 2004 //編號為2004的老師有一個編號為1002的學生
9,合並結果集
要求要合並的結果集中,列的類型和列數相同
UNION,去除重復行,UNION ALL,不去除重復行