• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >oracle > Oracle约束管理脚本

Oracle约束管理脚本

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了oracle执行sql脚本,oracle定时备份脚本,oracle数据库脚本,oracle导入sql脚本,oracle rman备份脚本等相关知识,希望本文的分享对您有所帮助
正在看的ORACLE教程是:Oracle约束管理脚本。

作为一个Oracle数据库管理员,会碰到这样的数据库管理需求,停止或者打开当前用户(模式)下所有表的约束条件和触发器。这在数据库的合并以及对数据库系统的代码表中某些代码的修改时需要做的工作之一。 

  我们来看这样一种实际数据库工作业务需求,这在目前的许多应用中是非常实际的。某地区银行数据,目前采用市级数据集中,随着计算机网络技术的不断提高以及对服务水平的要求,提出了省级乃至国家级的数据集中。除了应用需要修改以外,对于数据库管理员来讲,最重要的工作就是对各地分散管理的数据库统一集中到一个或者几个集中数据库中。此时就需要整理以前各地各自为政的代码表为一个统一的代码表以及数据库的最后集中合并。 

  对Oracle数据库管理员来讲,这样的数据维护工作,在更新代码表中代码或者合并数据之前,首先要作的工作就是将系统中某用户下所有的外键或触发器停止,处理完数据后,再打开这些关闭的外键和触发器。针对这样的工作需求,本文给出了下面两个SQL脚本:(1) 系统中某模式或用户下外键或者触发器的管理脚本;(2) 外键错误自动查找脚本。下面就来详细介绍这两个脚本。 

  一、约束管理脚本

  该脚本可用来管理当前登录用户下的所有外键和触发器的打开和关闭,此处没有处理主键和唯一约束条件,该脚本稍加修改就可以处理主键和唯一约束条件,但这里建议最好不要在随意停止主键或唯一约束条件后,进行数据维护。 

  脚本运行方法如下(SQL/PLUS): 


  其中,参数as_alter只能是“ENABLE”或者“DISABLE”,否则程序提示错误。当参数为“ENABLE”时,表示将当前模式下所有的外键和触发器打开,相反“DISABLE”就是将当前模式下所有的外键和触发器关闭。 

  附存储过程脚本: 


  判断输入参数是否为DISABLE或者是ENABLE,如果是的话,就继续处理,否则退出过程,给出提示
IF (UPPER(AS_ALTER) = 'DISABLE' OR UPPER(AS_ALTER) = 'ENABLE') THEN
OPEN C_CON;

[NextPage]

当前用户下外键的处理 ENABLE或者 DISABLE


  二、约束错误自动查找脚本 

  一般,数据库管理员在对数据进行维护时,如新数据的导入前,首先要关闭所有的外键和触发器,数据成功导入后,再打开导入前关闭的外键和触发器。这时经常会遇到错误号为ORA-02298的“未找到父项关键字”的错误。该错误的原因就是数据库表中出现了不能满足外键约束条件的记录。这里,另外给出了一个脚本(P_CON_ERR)用来自动查找造成这类错误的原因,也就是找出不满足外键约束条件的字段值。 

  该存储过程可单独运行,同时在前面介绍的存储过程P_ALTERCONS中也进行了调用,在存储过程P_ALTERCONS中,可以看到在打开外键时,如果出现错误号为ORA-02298的错误,就调用该存储过程,自动查找造成外键不能启动的原因。 

  下面是单独运行该存储过程的例子,在SQL/PLUS环境下: 

PL/SQL过程已成功完成。 

  其中,FK_SB_HJJL_RELATION__SB_PZXH为出现错误的外键名称。 

  附存储过程脚本: 

上一页    

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Oracle中查看慢查询进度的脚本分享
  • Oracle中查看表空间使用率的SQL脚本分享
  • Oracle 获得以百分号结尾的脚本有三种写法
  • Oracle提高SQL执行效率的3种方法
  • Oracle提高sql执行效率的心得建议
  • oracle 服务启动,关闭脚本(windows系统下)
  • Oracle约束管理脚本

相关文章

  • 2017-05-11Oracle round()函数与trunc()函数区别介绍
  • 2017-05-11Oracle Portal及其门户网站开发概述
  • 2017-05-11MySQL安全性指南 (1)(转)
  • 2017-05-11Oracle 11g收集多列统计信息详解
  • 2017-05-11Oracle 系统变量函数介绍
  • 2017-05-11Oracle 使用TOAD实现导入导出Excel数据
  • 2017-05-11数据库Oracle数据的异地的自动备份
  • 2017-05-11分享Oracle 11G Client 客户端安装步骤(图文详解)
  • 2017-05-11[Oracle] 浅谈Lock与Latch
  • 2017-05-11Oracle批量执行sql语句之禁用所有表的外键

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • oracle创建数据库和用户的方法
    • Oracle index索引
    • oracle客户端PLSQL连接失败解决方法
    • [Oracle] Data Guard 之 浅析Switchover与Failover
    • oracle如何使用java source调用外部程序
    • windows 7下Oracle 11g安装图文教程
    • Oracle10g通过DBLink访问MySQL示例
    • Oracle 跨库 查询 复制表数据 分布式查询介绍
    • 误删除$ORACLE_HOME/dbs下的参数文件、密码文件快速重建的方法
    • 解决plsql连接失败,弹出空白提示框的方法详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有