Oracle中动态建表--学习笔记


    由于在存储过程中不支持DML数据控制语言,只能进行DDL数据定义语言,所以,如果想在存储过程中创建或者是删除表的话,就不能用到create table和drop table语句直接执行了,而要用到那可以用executeimmediate(如果Oracle版本是8.15以上),就如同我们在C#或者JAVA连接到数据库之后,执行一条SQL语句一样,先将SQL语句用字符串的形式保存,然后用执行SQL的语句进行执行。另外还因该注意的是,在存储过程中建表需要显式地授予用户create table的权限:grant create table to 用户名;
   
    我们要在数据库中动态创建一个名为t323的表,不能写成:
          create or replace procedrue create_table
          as
            create table t323
            (sno int,
             sname varchar2(12))
          end;
          /

    示例代码如下:
          create or replace procedure drop_tb      --判断是否存在表t323,若有,drop掉先
          as
              vtb int;
              sqlstr varchar2(50);
          begin                                                          --判断是否存在
               select count(*) into vtb from tabs where table_name=upper('t323');
               if vtb=1 then

                  sqlstr:='drop table t323';
                  execute immediate(sqlstr);
        --执行drop table指令
               end if;
          end;
          /
          exec drop_tb;
                                       --执行drop存储过程
         
          grant create table to wangc;              --授予用户Create权限
          create or replace procedure create_tb
          as
               sqlstr varchar2(50);
          begin
               sqlstr:='create table t323(sno int,sname varchar2(12))';
               execute immediate(sqlstr);
          --执行create table指令
          end;
          /
          exec create_tb;
                                    --执行create存储过程

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值