這個(gè)用外鍵關(guān)聯(lián)自己表的主鍵最理想!
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、成都小程序開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了杭錦免費(fèi)建站歡迎大家使用!
建表如下!這樣建的表就滿(mǎn)足你的要求,適用于客戶(hù)和推薦人
create table emp1(
empno number(4) constraint emp1_empno_pk primary key,
mgr number(4) constraint emp1_mgr_fk emp1(empno)
);
一、Oracle數(shù)據(jù)庫(kù):禁用約束基本語(yǔ)法:alter table 數(shù)據(jù)庫(kù)表名 disable constraint 約束名 假設(shè)現(xiàn)在需要關(guān)閉pub_organ的外鍵約束:1、 首先查詢(xún)pub_organ存在哪些外鍵約束,此時(shí)需要用到oracle的字典表user_constraints。select * from user_constraints where table_name='PUB_ORGAN'; 上圖就是查詢(xún)結(jié)果,其中各字段含義如下:OWNER: 表的所有者CONSTRAINT_NAME: 約束名稱(chēng)CONSTRAINT_TYPE: 約束類(lèi)型(R代表外鍵,P代表主鍵,C代表check約束)TABLE_NAME: 表名稱(chēng)SEARCH_CONDITION: check約束的具體信息STATUS: ENABLED表示當(dāng)前約束是啟用的,DISABLED表示當(dāng)前約束未啟用。2、 查詢(xún)出表存在哪些約束后,即可以通過(guò)alter語(yǔ)句啟用或禁用指定的約束了。如禁用pub_organ表的外鍵PUBORGAN_FK1,則可以使用如下命令實(shí)現(xiàn):alter table PUB_ORGAN disable constraint PUBORGAN_FK1;執(zhí)行后,再次查詢(xún)字典表user_constraints,如下: 此時(shí)往數(shù)據(jù)庫(kù)表pub_organ中插入數(shù)據(jù)時(shí)就不再受外鍵約束的影響了。 啟用約束基本語(yǔ)法:alter table 數(shù)據(jù)庫(kù)表名 enable constraint 約束名 如現(xiàn)在需要重新啟用pub_organ的外鍵約束,可以使用如下命令:alter table PUB_ORGAN enable constraint PUBORGAN_FK1;二、DB2數(shù)據(jù)庫(kù):禁用約束基本語(yǔ)法:ALTER TABLE 表名稱(chēng) ALTER FOREIGN KEY 約束名稱(chēng) NOT ENFORCED 啟用約束基本語(yǔ)法:ALTER TABLE 表名稱(chēng) ALTER FOREIGN KEY 約束名稱(chēng) ENFORCED 相關(guān)字典表:SYSIBM.SYSTABCONST如:select * from SYSIBM.SYSTABCONST where tbname='PUB_ORGAN'; 各字段含義如下:NAME: 約束名稱(chēng)DEFINER: 定義者CONSTRAINTTYP: 約束類(lèi)型(P代表主鍵,F(xiàn)代表外鍵)TBNAME: 表名稱(chēng)ENFORCED: 是否啟用(Y代表啟用,N代表未啟用)三、封裝成java接口、批量執(zhí)行在實(shí)際工作中,經(jīng)常會(huì)將若干個(gè)表,或者所有數(shù)據(jù)庫(kù)表的外鍵一起禁用,此時(shí)需要批量執(zhí)行相關(guān)命令,筆者根據(jù)工作實(shí)際,使用java封裝了相關(guān)接口,以方便使用。對(duì)外暴露接口如下:/* * 啟用當(dāng)前用戶(hù)指定tableName的所有外鍵約束 * 入?yún)⑹褂每勺儏?shù)(jdk5新特性) * 調(diào)用方式: * 1、enableFK("pub_organ") * 2、enableFK("pub_organ","pub_stru") * 3、enableFK(new String[]{"pub_organ","pub_stru"}) */ publicstaticvoidenableFK(String...tableNames){ disableORenbaleFK(true,tableNames); }/* * 禁用當(dāng)前用戶(hù)指定tableName的所有外鍵約束 */ publicstaticvoiddisableFK(String...tableNames){ disableORenbaleFK(false,tableNames); }/* * 啟用當(dāng)前用戶(hù)所有表的外鍵約束 */ publicstaticvoid enableAllFK(){ disableORenableAllConstraint(true); } /* * 禁用當(dāng)前用戶(hù)所有表的外鍵約束 */ publicstaticvoid disableAllFK(){ disableORenableAllConstraint(false); } 其中核心處理代碼如下: if(tableNames==null||tableNames.length==0){ thrownew RuntimeException("入?yún)ableNames不能為空!"); } //查詢(xún)指定表的外鍵約束 String sql = null; String dbType = getDBType(); if(dbType.contains("ORACLE")){ sql = "select 'alter table ' || table_name || ' disable constraint ' || constraint_name from user_constraints where constraint_type='R' and TABLE_NAME in("; if(isEnable){ sql = sql.replace("disable", "enable"); } }elseif(dbType.contains("DB2")){ sql = "select 'ALTER TABLE ' || TBNAME || ' ALTER FOREIGN KEY ' || NAME ||' NOT ENFORCED ' FROM SYSIBM.SYSTABCONST WHERE CONSTRAINTYP='F' and TBNAME in("; if(isEnable){ sql = sql.replace("NOT ENFORCED", "ENFORCED"); } }else{ thrownew RuntimeException("數(shù)據(jù)庫(kù)類(lèi)型無(wú)效(僅支持Oracle和DB2),dbType="+dbType); } StringBuffer generateSQL = new StringBuffer(sql); for(int i=0;i
NOT NULL (非空)--防止NULL值進(jìn)入指定的列,在單列基礎(chǔ)上定義,默認(rèn)情況下,ORACLE允許在任何列中有NULL值.
CHECK (檢查)--檢查在約束中指定的條件是否得到了滿(mǎn)足.
UNIQUE (唯一)--保證在指定的列中沒(méi)有重復(fù)值.在該表中每一個(gè)值或者每一組值都將是唯一的.
PRIMARY KEY (主鍵)--用來(lái)唯一的標(biāo)識(shí)出表的每一行,并且防止出現(xiàn)NULL值,一個(gè)表只能有一個(gè)主鍵約束.
POREIGN KEY (外部鍵)--通過(guò)使用公共列在表之間建立一種父子(parent-child)關(guān)系,在表上定義的外部鍵可以指向主鍵或者其他表的唯一鍵.
查看表的約束條件有三個(gè)視圖:
1、dba_constraints、all_constraints、user_constraints。
2、其中:dba_constraints視圖需要DBA權(quán)限才能查詢(xún)。
3、all_constraints、user_constraints普通用戶(hù)查詢(xún)。
擴(kuò)展資料:
Oracle數(shù)據(jù)庫(kù)使用約束(constraints)來(lái)防止無(wú)效的數(shù)據(jù)進(jìn)入表中,保護(hù)數(shù)據(jù)的實(shí)體完整行約束定義在表級(jí),如果表與表之間有從屬關(guān)系,約束可以防止表的刪除,通過(guò)約束字段,強(qiáng)制用戶(hù)在插入更新和刪除數(shù)據(jù)時(shí)必須遵循一定的規(guī)則。
約束定義語(yǔ)法: create table 表名(字段名 數(shù)據(jù)類(lèi)型 約束類(lèi)型) 或 create table 表名(字段名1 數(shù)據(jù)類(lèi)型,字段名2,數(shù)據(jù)類(lèi)型 constraints 約束別名 約束類(lèi)型 (字段))
工具/材料
SQL Developer
01
首先打開(kāi)SQL Developer軟件,找一個(gè)沒(méi)有主鍵約束的表,如下圖所示
02
然后我們新建一個(gè)查詢(xún),在界面中輸入如下的約束修改語(yǔ)句,如下圖所示,主要通過(guò)add constranint來(lái)添加約束
03
編寫(xiě)完約束添加語(yǔ)句以后,點(diǎn)擊工具欄中的執(zhí)行按鈕,如下圖所示,如果輸出欄顯示已變更則證明主鍵約束創(chuàng)建成果
04
然后我們進(jìn)入STUDENT表的約束添加頁(yè)中可以看到,我們加的主鍵約束已經(jīng)添加進(jìn)去了,如下圖所示
05
另外,創(chuàng)建表的時(shí)候可以直接添加主鍵約束,如下圖所示,直接在表創(chuàng)建語(yǔ)句中添加constraint即可
06
表創(chuàng)建完以后,記得在左側(cè)刷新數(shù)據(jù)庫(kù)信息,如下圖所示,因?yàn)槟銊?chuàng)建的信息不刷新的話(huà)不會(huì)更新
07
最后打開(kāi)你所創(chuàng)建的表,看到你添加的主鍵約束已經(jīng)加入進(jìn)來(lái)了,這種方式的效果alter的方式是一樣的
方法給你 你自己設(shè)置吧
修改不同的表要寫(xiě)不同的alter table 不同的表
alter table 你的表--此為修改表約束
add /*必須包含add 添加*/ constraint/*約束,也必須包含*/
--固定用法
alter table '表名'
add constraint 約束名 約束類(lèi)型 約束描述
/*對(duì)應(yīng)約束*/
alter table '表名'
add
--主鍵
constraint PK_字段/*此為命名規(guī)范要求*/ primary key(字段),
--唯一約束
constraint UK_字段 unique key(字段),
--默認(rèn)約束
constrint DF_字段 default('默認(rèn)值') for/*到*/ 字段,
--檢查約束
constraint CK_字段 check(約束。如:len(字段)1),
--主外鍵關(guān)系
constraint FK_主表_從表 foreign(外鍵字段) references 主表(主表主鍵字段)
go--后續(xù) 一般約束是寫(xiě)在建表之后的
最后 給你寫(xiě)下限制時(shí)間的約束
alter table 表
add constraint CK_Date
check(列 between '1900-1-1 ' and '2990-1-1')