首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > Oracle中动态建表--学习笔记
【标  题】:Oracle中动态建表--学习笔记
【关键字】:Oracle,--
【来  源】:http://blog.csdn.net/camio007/archive/2007/03/07/1523297.aspx

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存储过程

关于Oracle中select * from where 的存储过程:【上一篇】
存储过程实例(二):【下一篇】
【相关文章】
  • 关于Oracle中select * from where 的存储过程
  • oracle的伪列以及伪表
  • oracle数据库命令行导入导出
  • java学习笔记---String类
  • Oracle开放Oracle App Server与Spring Framework的集成代码
  • oracle10学习日记-0306sqlplus新建表
  • Oracle EMPTY_BLOB() EMPTY_CLOB()
  • linux 系统管理之入门-----安装
  • 从SNMP到WBEM--论网络和系统管理的发展和展望(SNMP篇)
  • 工作日志(2007.3.1--2) --GRAPPLE开发方法学的练习
  • 【随机文章】
  • Freehand 渐变的模拟
  • Vim 的一点使用
  • 嵌入式系统中LCD驱动的实现原理
  • JDBC call Stored Procedure
  • linux bible 第十三章 处理器
  • 用jdom生成普通xml格式与生成SOAP所需要的xml格式 实例
  • 使用vmware安装6.1
  • Openbsd
  • 详细解说 STL 排序(Sort)
  • 双向HFC网的建设和改造
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.