您现在的位置是:网站首页> 编程资料编程资料
Oracle批量执行sql语句之禁用所有表的外键_oracle_
2023-05-27
372人已围观
简介 Oracle批量执行sql语句之禁用所有表的外键_oracle_
在转移数据库,进行数据导入的时候,遇到一件麻烦事,就是表间外键约束的存在,导致insert频频报错,批量执行sql语句又是顺序执行,没办法我只好手动输入。
然后输入到一半灵光一闪,为什么不先把外键约束全部禁用先呢?
于是我百度到以下资料:
oracle 删除(所有)约束 禁用(所有)约束 启用(所有)约束
执行以下sql生成的语句即可
1删除所有外键约束
select 'alter table '||table_name||' drop constraint '||constraint_name||';' from user_constraints where constraint_type='R'
2禁用所有外键约束
select 'alter table '||table_name||' disable constraint '||constraint_name||';' from user_constraints where constraint_type='R'
3启用所有外键约束
select 'alter table '||table_name||' enable constraint '||constraint_name||';' from user_constraints where constraint_type='R'
在SQL Plus中输入语句后,生成了很多语句,这些语句其实是没执行的,复制下来执行一遍就好了。
然后我们可以根据这个脚本一样的sql语句进行拼装,得到我们需要的语句:
禁用所有外键约束:
select 'ALTER TABLE "QIANHAI"."'||table_name||'" MODIFY CONSTRAINT "'||constraint_name||'" DISABLE;' from user_constraints where constraint_type='R'
启用所有外键约束:
select 'ALTER TABLE "QIANHAI"."'||table_name||'" MODIFY CONSTRAINT "'||constraint_name||'" ENABLE;' from user_constraints where constraint_type='R';
关于Oracle批量执行sql语句之禁用所有表的外键的相关内容,就给大家介绍这么多,后续还会持续更新,感兴趣的朋友请继续关注网站,谢谢!
您可能感兴趣的文章:
- Oracle批量插入数据的三种方式【推荐】
- C# Oracle批量插入数据进度条的实现代码
- Oracle + Mybatis实现批量插入、更新和删除示例代码
- MyBatis批量插入数据到Oracle数据库中的两种方式(实例代码)
- Oracle两张表关联批量更新其中一张表的数据
- Oracle批量查询、删除、更新使用BULK COLLECT提高效率
- mybatis执行批量更新batch update 的方法(oracle,mysql两种)
- Oracle批量导入文本文件快速的方法(sqlldr实现)
- Oracle+Mybatis的foreach insert批量插入报错的快速解决办法
- Java实现mybatis批量插入数据到Oracle
- oracle+mybatis 使用动态Sql当插入字段不确定的情况下实现批量insert
- Oracle 高速批量数据加载工具sql*loader使用说明
- Oracle数据库更新大批量数据案例
相关内容
- Oracle SqlPlus设置Login.sql的技巧_oracle_
- 讲解Oracle数据库中结束死锁进程的一般方法_oracle_
- Oracle数据表中的死锁情况解决方法_oracle_
- 简单说明Oracle数据库中对死锁的查询及解决方法_oracle_
- Oracle数据库中外键的相关操作整理_oracle_
- 在Oracle数据库中添加外键约束的方法详解_oracle_
- 在Linux系统上同时监控多个Oracle数据库表空间的方法_oracle_
- 整理Oracle数据库中数据查询优化的一些关键点_oracle_
- Oracle数据库中基本的查询优化与子查询优化讲解_oracle_
- 一些Oracle数据库中的查询优化建议综合_oracle_
