使用存储过程删除,创建表

create or replace procedure CREATETABLETEST is

  str1    varchar2(1000);

  str2    varchar2(5000);

  v_count number(10);

begin

  select count(1)

    into v_count

    from user_tables

   where table_name = 'TESTTABLE';--查找表TESTTABLE是否存在

  str1 := 'DROP TABLE ' || 'TESTTABLE';--删除表TESTTABLE

  str2 := 'CREATE TABLE TESTTABLE AS SELECT * FROM DOCUMENTVIEW';--创建表TESTTABLE,将表DOCUMENTVIEW 的数据写入到TESTTABLE中

 

  --判断表TESTTABLE是否存在,存在先删除表,不存在创建表

  if (v_count < 0) then

    execute immediate str1;

  end if;

  execute immediate str2;

end CREATETABLETEST;

--在测试该存储过程的时候,有可能在CREATE TABLE 处 提示 '权限不足' 的错误。给该数据用户一个创建表的权限就可以了。例:用户名 TESTUSER, 在SQLPLUS 中,以DBA权限进入,输入  grant createtable to TESTUSER;  即可解决该问题。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值