关闭数据库外键约束

本文的测试环境是:

  • MySQL 5.5.16
  • Microsoft SQL Server 2008 R2 (SP2)
  • Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

当向数据库中插入数据的时候,如果有表之间的关系十分复杂,尤其是是存在各种外键关系,这是需要暂时关闭这种针对外键约束的检查,本文针对以下三种数据库进行了一个总结,如下:

一、MySQL数据库

MySQL中数据库中的外键约束是通过变量foreign_key_checks作用的,这个变量管理的全局的外键约束,而没有针对每个表的外键约束进行单独管理

1. 查看变量外键约束

  • show variables like '%foreign_key_checks%'
  • select @@foreign_key_checks

2. 开启外键约束:

set foreign_key_checks = 1

3.关闭外键约束:

set foreign_key_checks = 0

二、SQL Server数据库

SQL Server数据库中针对外键约束进行了统一的管理,它的粒度已经到表的层次,而不像MySQL中的那样只能对全局进行设置。SQL Server中外键约束的管理是通过系统的存储过程来实现的,如下:

sp_helpconstraint [ @objname = ] 'table'   [ , [ @nomsg = ] 'no_message' ]
  • @objname:约束信息所在的表名,类型为nvarchar(776),没有默认值;
  • @nomsg:要打印表名信息,几乎不用;

1. 查看约束信息

EXEC sp_helpconstraint 't_archetype_revision_file'

关闭数据库外键约束_第1张图片

在存储过程中查询到的约束信息有:

  • Constraint_Type:列的约束类型,约束的类型有:
    • PRIMARY KEY
    • FOREIGN KEY
    • DEFAULT
    • CHECK
  • Constraint_Name:用户或者系统定义的约束名称;
  • Delete_action :针对外键约束,当外键删除时采取的操作,为No Action或者cascade;
  • Update_Action:针对外键约束,当外键更新时采取的操作,为No Action或者cascade;
  • Status_Enabled :针对外键约束和check约束,是否启用,当约束建立时默认是启用的;
  • Status_For_Replication :针对外键和check约束,当复制的时候是否强制执行;
  • Constraint_Keys :针对check和default约束显示的是表达式,针对其他约束显示的是列名;

2. 开启外键约束

通过Alter Table语句完成,示例如下:

Alter Table t_archetype_revision_file CHECK CONSTRAINT FK1jdbfqwxvcn37y16ofob43ywf

3. 关闭外键约束

Alter Table t_archetype_revision_file NOCHECK CONSTRAINT FK1jdbfqwxvcn37y16ofob43ywf

三、Oracle数据库

Oracle中的外键约束的管理与SQL Server中的类似,也是统一管理的,针对的也是表的层次。外键约束的统一管理是在数据字典表user_constraints中。

1.查看约束

SELECT * FROM user_constraints

在里面有很多的字段,这里我们只关注相关的几项:

  • CONSTRAINT_NAME:约束名称;
  • CONSTRAINT__TYPE:约束类型,包括:
    • R:外键约束;
    • U:唯一约束;
    • P:主键约束;
    • C:check约束;
    • O:用于视图,只读约束;
    • ……
  • TABLE_NAME:约束所在的表;
  • STATUS:使用状态,ENABLED标识启用,DISABLED标识禁用;

但是在这个视图中,没有约束对应的表的列,可以通过连接user_cons_columns来查询,如下:

SELECT * FROM user_constraints t1 left join user_cons_columns t2 on t1.CONSTRAINT_NAME = t2.CONSTRAINT_NAME where t1.CONSTRAINT_NAME = 'LOGMNR_SESSION_EVOLVE$_PK'

2. 开启外键约束

默认情况下,建立约束时开启该约束。

alter table table_name enable constraint constraint_name 

3. 关闭外键约束

alter table table_name disable constraint constraint_name

你可能感兴趣的:(Database,MySQL)