1、外鍵是屬于約束的一種,所謂約束顧名思義,就是限制你在數(shù)據(jù)庫的操作。而你對數(shù)據(jù)庫有什么操作,無非是增、刪、改、查,外鍵起的作用就是讓你在數(shù)據(jù)庫幫助的情況下更合理的增加數(shù)據(jù)的正確度。
我們一直強(qiáng)調(diào)成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站對于企業(yè)的重要性,如果您也覺得重要,那么就需要我們慎重對待,選擇一個安全靠譜的網(wǎng)站建設(shè)公司,企業(yè)網(wǎng)站我們建議是要么不做,要么就做好,讓網(wǎng)站能真正成為企業(yè)發(fā)展過程中的有力推手。專業(yè)網(wǎng)絡(luò)公司不一定是大公司,成都創(chuàng)新互聯(lián)公司作為專業(yè)的網(wǎng)絡(luò)公司選擇我們就是放心。
2、所以,外鍵只是輔助,并不能起到你說的【B.NAME是否也自動出現(xiàn)張三兩個字】。
3、外鍵的作用是能夠避免如下情況。
如
【班級信息表】存放的是班級信息表。
【學(xué)生表】存放的是學(xué)生信息,包含班級信息。
這個時候 在【學(xué)生表】中存放的班級信息應(yīng)該在【班級信息表】存在才合法,自己人為控制的話難免有漏掉的情況,用外鍵則可以讓數(shù)據(jù)庫自動控制,當(dāng)插入【學(xué)生表】中的數(shù)據(jù)在【班級信息表】不存在的時候,數(shù)據(jù)庫不允許插入。
---
以上,希望對你有所幫助。
主鍵:ALTER TABLE A ADD CONSTRAINT PK_XXX PRIMARY KEY (XXX)
外鍵;ALTER TABLE B ADD CONSTRAINT FK_YYY FOREIGN KEY(YYY) REFERENCES A(XXX)
B表的YYY字段 引用A表的XXX字段值域?yàn)樽陨碇涤?/p>
主鍵約束,外鍵約束就是這樣建立的
刪除約束: ALTER TABLE A DROP CONSTRAINT 約束名
3 stuid number(10) references t_stu(stuid) 就是這個字段關(guān)聯(lián)t_stu表的stuid字段;
4 couseid number(10),
5 constraint fk_couseid foreign key(couseid)
6 references t_couse(couseid)
7 on delete cascade); 這個是外鍵關(guān)聯(lián),并做同步刪除操作,就是如果t_couse表中的某個couseid數(shù)據(jù)被刪除了,那么這張表相關(guān)的數(shù)據(jù)也會自動被刪除;跟上面的區(qū)別就在于有沒有做刪除操作;
on delete cascade 就是同步刪除的意思,比如t_couse表中有個couseid=5,t_score表中也有couseid=5的數(shù)據(jù),當(dāng)刪除t_couse表中couseid=5的數(shù)據(jù)時,t_score表中所有couseid=5的數(shù)據(jù)也會自動刪除;
可以寫在同一行,但是要用逗號分格開; 望采納,碼字不容易
1、執(zhí)行Oracle Uninstall,卸載Oracle產(chǎn)品
2、刪除regedit下的所有Oracle相關(guān)項(xiàng)
3、重啟機(jī)器
4、sc delete 刪除Oracle的相關(guān)服務(wù)
5、手動刪除Oracle_Home目錄,以及C:\Program Files下的Oracle目錄
6、刪除手動添加的環(huán)境變量 注:必須要刪除自己添加的環(huán)境變量,我就因?yàn)殚_始沒有刪除ORACLE_HOME,導(dǎo)致一直出錯,痛苦了N久才搞定。
就是正常的alter table語句。
alter table mid_b_table add constraint b_fk foreign key(deptno) references mid_a_table(deptno) on delete cascade;
要注意的是如果你刪除了一段時間,數(shù)據(jù)發(fā)生了變化,可能原來的外鍵無法重建,原因是出現(xiàn)了父表和子表數(shù)據(jù)不一致的狀態(tài),這時可以考慮調(diào)整on delete cascade選項(xiàng),但更普遍的要先檢查數(shù)據(jù)的一致性并適當(dāng)修改不一致的數(shù)據(jù)。
詳細(xì)可見參考資料。
以oracle自帶的用戶scott為例。
create?table?dept(
deptno?number(2)?primary?key,?--deptno?為?dept表的主鍵
dname?varchar2(10),
loc?varchar2(9)
);
create?table?emp(
empno?number(4)?primary?key,?--empno?為?emp表的主鍵
ename?varchar2(10),
job?varchar2(9),
mgr?number(4),
hiredate?date,
sal?number(7,2),
comm?number(7,2),
deptno?number(2)?references?dept(deptno)?--dept表中deptno字段?為?emp表的外鍵
);