1、ORACLE數(shù)據(jù)庫中的外鍵約束名都在表user_constraints中可以查到。其中constraint_type='R'表示是外鍵約束。
呼蘭ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18982081108(備注:SSL證書合作)期待與您的合作!
2、啟用外鍵約束的命令為:alter
table
table_name
enable
constraint
constraint_name
3、禁用外鍵約束的命令為:alter
table
table_name
disable
constraint
constraint_name
4、然后再用SQL查出數(shù)據(jù)庫中所以外鍵的約束名:
select
'alter
table
'||table_name||'
enable
constraint
'||constraint_name||';'
from
user_constraints
where
constraint_type='R'
select
'alter
table
'||table_name||'
disable
constraint
'||constraint_name||';'
from
user_constraints
where
constraint_type='R'
禁用oracle 的 XDB服務(wù)的方法很簡單,去掉相應(yīng)的數(shù)據(jù)庫的初始化參數(shù)即可: 編輯$ORACLE_HOME/dbs/initSID.ora文件,去除如下行: dispatchers='(PROTOCOL=TCP) (SERVICE=XDB)'重啟數(shù)據(jù)庫 shutdown immediate; create spfile from pfile; startup;修改XDB服務(wù)端口: XDB的http服務(wù)就占用8080端口,剛好和JBoss、Tomcat等默認端口沖突,Oracle XDB的端口設(shè)置不在配置文件中,而是在數(shù)據(jù)庫里。如下修改XDB的http和ftp服務(wù)端口: 使用sys登錄sqlplus,利用dbms_xdb修改端口設(shè)置 SQL -- Change the HTTP /WEBDAV port from 8080 to 8081 SQL call dbms_xdb.cfg_update(updateXML( 2 dbms_xdb.cfg_get() 3 , '/xdbconfig/sysconfig/protocolconfig /httpconfig/http-port/text()' 4 , 8081)) 5 / Call completed. SQL -- Change the FTP port from 2100 to 2111 SQL call dbms_xdb.cfg_update(updateXML( 2 dbms_xdb.cfg_get() 3 , '/xdbconfig/sysconfig/protocolconfig /ftpconfig/ftp-port/text()' 4 , 2111)) 5 / Call completed. SQL COMMIT; Commit complete. SQL EXEC dbms_xdb.cfg_refresh; PL/SQL procedure successfully completed.(責(zé)任編輯:盧兆林)
一、Oracle數(shù)據(jù)庫:禁用約束基本語法:alter table 數(shù)據(jù)庫表名 disable constraint 約束名 假設(shè)現(xiàn)在需要關(guān)閉pub_organ的外鍵約束:1、 首先查詢pub_organ存在哪些外鍵約束,此時需要用到oracle的字典表user_constraints。select * from user_constraints where table_name='PUB_ORGAN'; 上圖就是查詢結(jié)果,其中各字段含義如下:OWNER: 表的所有者CONSTRAINT_NAME: 約束名稱CONSTRAINT_TYPE: 約束類型(R代表外鍵,P代表主鍵,C代表check約束)TABLE_NAME: 表名稱SEARCH_CONDITION: check約束的具體信息STATUS: ENABLED表示當(dāng)前約束是啟用的,DISABLED表示當(dāng)前約束未啟用。2、 查詢出表存在哪些約束后,即可以通過alter語句啟用或禁用指定的約束了。如禁用pub_organ表的外鍵PUBORGAN_FK1,則可以使用如下命令實現(xiàn):alter table PUB_ORGAN disable constraint PUBORGAN_FK1;執(zhí)行后,再次查詢字典表user_constraints,如下: 此時往數(shù)據(jù)庫表pub_organ中插入數(shù)據(jù)時就不再受外鍵約束的影響了。 啟用約束基本語法:alter table 數(shù)據(jù)庫表名 enable constraint 約束名 如現(xiàn)在需要重新啟用pub_organ的外鍵約束,可以使用如下命令:alter table PUB_ORGAN enable constraint PUBORGAN_FK1;二、DB2數(shù)據(jù)庫:禁用約束基本語法:ALTER TABLE 表名稱 ALTER FOREIGN KEY 約束名稱 NOT ENFORCED 啟用約束基本語法:ALTER TABLE 表名稱 ALTER FOREIGN KEY 約束名稱 ENFORCED 相關(guān)字典表:SYSIBM.SYSTABCONST如:select * from SYSIBM.SYSTABCONST where tbname='PUB_ORGAN'; 各字段含義如下:NAME: 約束名稱DEFINER: 定義者CONSTRAINTTYP: 約束類型(P代表主鍵,F(xiàn)代表外鍵)TBNAME: 表名稱ENFORCED: 是否啟用(Y代表啟用,N代表未啟用)三、封裝成java接口、批量執(zhí)行在實際工作中,經(jīng)常會將若干個表,或者所有數(shù)據(jù)庫表的外鍵一起禁用,此時需要批量執(zhí)行相關(guān)命令,筆者根據(jù)工作實際,使用java封裝了相關(guān)接口,以方便使用。對外暴露接口如下:/* * 啟用當(dāng)前用戶指定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)前用戶指定tableName的所有外鍵約束 */ publicstaticvoiddisableFK(String...tableNames){ disableORenbaleFK(false,tableNames); }/* * 啟用當(dāng)前用戶所有表的外鍵約束 */ publicstaticvoid enableAllFK(){ disableORenableAllConstraint(true); } /* * 禁用當(dāng)前用戶所有表的外鍵約束 */ publicstaticvoid disableAllFK(){ disableORenableAllConstraint(false); } 其中核心處理代碼如下: if(tableNames==null||tableNames.length==0){ thrownew RuntimeException("入?yún)ableNames不能為空!"); } //查詢指定表的外鍵約束 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ù)庫類型無效(僅支持Oracle和DB2),dbType="+dbType); } StringBuffer generateSQL = new StringBuffer(sql); for(int i=0;i
在服務(wù)中直接停止即可。
1、以windows10為例,右鍵“此電腦”,選擇“管理”。
2、然后選擇“服務(wù)和應(yīng)用程序”——“服務(wù)”。
3、找到oracle的服務(wù),一般名稱為oracleservice+實例名。
4 、右鍵,選擇停止,等待執(zhí)行完畢即可。