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

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;  即可解决该问题。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值