Oracle存储过程实现重新建表

该博客介绍了如何使用Oracle存储过程在保留原有数据、结构、约束、索引及注释的情况下,重新创建表。首先,阐述了案例背景,接着详细说明了所需的环境准备,包括用户权限设置,最后揭示了存储过程的具体实现。

1、案例说明

通过存储过程,在保留原表的数据、表结构、约束、索引,以及表和字段注释的前提下,一键重新创建表。

2、环境准备

(1)创建存储过程的用户需要有数据字典视图DBA_TABLES、DBA_CONSTRAINTS、DBA_TAB_COMMENTS、DBA_COL_COMMENTS的查询权限。

grant select any dictionary to user

(2)执行存储过程的用户需要显示赋予删除表、创建表、创建索引权限。

DROP ANY TABLE
CREATE ANY TABLE
CREATE ANY INDEX

3、存过实现

CREATE OR REPLACE PROCEDURE P_F_TAB_RECREATE(P_OWNER VARCHAR2,
                                                P_TABLE VARCHAR2) AUTHID CURRENT_USER AS
  /* ================================================================================= *\
   *   名称:  重新创建表
   *   参数:  P_OWNER:用户名;P_TABLE:表名
   *   描述:1:
             2:
             3:
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ben@dw

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值