在oracle的存储过程中,不能直接使用DDL语句,比如create、alter、drop、truncate等。

那如果我们想在存储过程中建立一张临时表就只能使用动态sql语句了:

[sql] view plain copy print ?
  1. create or replace procedure pro as
  2. str_sql varchar2(100);
  3. begin
  4. -- 创建临时表
  5. str_sql := 'create global temporary table temp_table (
  6. col1 varchar2(10),
  7. col2 number
  8. ) on commit preserve rows';
  9. execute immediate str_sql;
  10. -- 使用临时表
  11. str_sql := 'insert into temp_table(col1, col2) values(''a'', 1)';
  12. execute immediate str_sql;
  13. -- 删除临时表
  14. str_sql := 'drop table temp_table';
  15. execute immediate str_sql;
  16. end;
create or replace procedure pro asstr_sql varchar2(100);
begin-- 创建临时表str_sql := 'create global temporary table temp_table (col1 varchar2(10),col2 number) on commit preserve rows';execute immediate str_sql;-- 使用临时表str_sql := 'insert into temp_table(col1, col2) values(''a'', 1)';execute immediate str_sql;-- 删除临时表str_sql := 'drop table temp_table';execute immediate str_sql;
end;

在oracle中,临时表分为会话级别(session)和事务级别(transaction)两种。

会话级的临时表在整个会话期间都存在,直到会话结束;事务级别的临时表数据在transaction结束后消失,即commit/rollback或结束会话时,

会清除临时表数据。

on commit preserve rows -- 会话级别临时表(退出登录会结束会话)

on commit delete rows -- 事务级别临时表(提交或回滚会结束事务)

1)ON COMMIT DELETE ROWS
它是临时表的默认参数,表示临时表中的数据仅在事物过程(Transaction)中有效,当事物提交(COMMIT)后,临时表的暂时段将被自动截断(TRUNCATE),但是临时表的结构 以及元数据还存储在用户的数据字典中。如果临时表完成它的使命后,最好删除临时表,否则数据库会残留很多临时表的表结构和元数据。
2)ON COMMIT PRESERVE ROWS
它表示临时表的内容可以跨事物而存在,不过,当该会话结束时,临时表的暂时段将随着会话的结束而被丢弃,临时表中的数据自然也就随之丢弃。但是临时表的结构以及元数据还存储在用户的数据字典中。如果临时表完成它的使命后,最好删除临时表,否则数据库会残留很多临时表的表结构和元数据。
1:会话级的临时表的数据和你当前会话有关系,当前SESSION不退出的情况下,临时表中的数据就还存在,临时表的数据只有当你退出当前SESSION的时候才被截断(TRUNCATE TABLE),如下所示:
会话级别的临时表创建:
CREATE GLOBAL TEMPORARY TABLE TMP_TEST
(
    ID NUMBER ,
    NAME VARCHAR2(32)
) ON COMMIT PRESERVE ROWS;

CREATE GLOBAL TEMPORARY TABLE TMP_TEST ON COMMIT PRESERVE ROWS
AS
SELECT * FROM TEST;
操作示例:
SQL> CREATE GLOBAL TEMPORARY TABLE TMP_TEST
(
   ID NUMBER ,
  NAME VARCHAR2(32)
) ON COMMIT PRESERVE ROWS;
Table created
SQL> INSERT INTO TMP_TEST
    SELECT 1, 'kerry' FROM DUAL;
1 row inserted
SQL> COMMIT;
Commit complete
SQL> SELECT * FROM TMP_TEST;
ID         NAME
---------- ----------------
1         kerry
SQL> INSERT INTO TMP_TEST
  SELECT 2, 'rouce' FROM DUAL;
1 row inserted
SQL> ROLLBACK;
Rollback complete
SQL> SELECT * FROM TMP_TEST;
ID           NAME
---------- ----------------------
1           kerry
SQL>
2:事务级的临时表(默认),这种类型的临时表与事务有关,当进行事务提交或者事务回滚的时候,临时表的数据将自行截断,即当COMMIT或ROLLBACK时,数据就会被TRUNCATE掉,其它的特性和会话级的临时表一致。
事务级临时表的创建方法:
CREATE GLOBAL TEMPORARY TABLE TMP_TEST
(
    ID NUMBER ,
    NAME VARCHAR2(32)
) ON COMMIT DELETE ROWS;

CREATE GLOBAL TEMPORARY TABLE TMP_TEST ON COMMIT DELETE AS SELECT * FROM TEST;
SQL> CREATE GLOBAL TEMPORARY TABLE TMP_TEST
(
    ID NUMBER ,
    NAME VARCHAR2(32)
) ON COMMIT DELETE ROWS;
Table created
SQL> INSERT INTO TMP_TEST
  SELECT 1, 'kerry' FROM DUAL;
1 row inserted
SQL> SELECT * FROM TMP_TEST;
ID           NAME
---------- ----------------------
1           kerry
SQL> COMMIT;
Commit complete
SQL> SELECT * FROM TMP_TEST;
ID             NAME
---------- ------------------------
SQL>

临时表优缺点:

1. 在仅仅查询数据时建议使用游标。

2. 临时表不会建立索引,所以如果数据量比较大或进行多次查询时,不推荐使用。



在oracle存储过程中创建临时表相关推荐

  1. java 创建临时表 oracle_在ORACLE存储过程中创建临时表

    在ORACLE存储过程中创建临时表 存储过程里不能直接使用DDL语句,所以只能使用动态SQL语句来执行 --ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后ORACLE将截 ...

  2. oracle临时表教程,在oracle存储过程中创建临时表

    在oracle的存储过程中,不能直接使用DDL语句,比如create.alter.drop.truncate等. 那如果我们想在存储过程中建立一张临时表就只能使用动态sql语句了: create or ...

  3. mysql语句创建临时表并存入数据_mysql实例:在存储过程中创建临时表并储存数据...

    在mysql存储过程中创建临时表,并保存数据到该表,然后根据存储过程调用的例子. 是学习mysql存储过程的好例子,值得参考. 代码: mysql> mysql> CREATE TABLE ...

  4. oracle数据存入临时表,oracle中创建临时表步骤

    当前位置:我的异常网» 数据库 » oracle中创建临时表步骤 oracle中创建临时表步骤 www.myexceptions.net  网友分享于:2014-06-08  浏览:4次 oracle ...

  5. mysql 存储过程临时表_在MySQL存储过程中创建的临时表的范围

    问题撤销!当我拼写正确的一切,问题消失了! 我有一个MySQL存储过程创建一个临时表.当我从mysql提示符调用过程时,它似乎运行成功,但是如果我从临时表中选择COUNT(*),我会收到一个错误,表示 ...

  6. mysql 过程 临时表_在存储过程mysql中创建临时表

    我有SQL Server的经验.这是我第一次使用mysql.我想在存储过程中创建一个临时表.我不知道我在这里错过了什么. 我想做的是: 循环遍历事件及其匹配项,并将这些匹配项插入到临时表中,然后从该临 ...

  7. Oracle存储过程中异常Exception的捕捉和处理

    Oracle存储过程中异常的捕捉和处理 CREATE OR REPLACE Procedure Proc_error_process ( v_IN in Varchar2, v_OUT Out Var ...

  8. Oracle数据库中的临时表

    概述 写这篇文章的起因,是由于客户存在这样的场景.每次登录时,需要创建一些临时表(业务上临时),然后插入一些数据,返回到客户端,然后删除这些表.最初用户用的是普通表,带来很大的开销.后来改为Globa ...

  9. oracle存储过程ddl,Oracle 存储过程中的DDL语句

    Oracle的存储过程,是我们使用数据库应用开发的重要工具手段.在存储过程中,我们大部分应用场景都是使用DML语句进行数据增删改操作.本篇中,我们一起探讨一下数据定义语句DDL在存储过程中使用的细节和 ...

最新文章

  1. Sampling Procedure 和 Sample-drawing Procedure, SAP QM里的双胞胎?
  2. 腐蚀单机怎么进_华强北淘来的iPhone6S,进水后严重腐蚀,小伙飞线拯救又赚到了!...
  3. 01:初识Redis
  4. Shell脚本实战之文件批量创建和修改
  5. HTTP 协议的三次握手
  6. php操作外部文件,php文件操作-将其他文件的数据添加到本文件中
  7. complementary prior
  8. 来做网课老师不?年薪两百万,上不封顶...
  9. python如何保存图像_Python应用引擎:如何保存图像?
  10. Linux服务器安装宝塔面板,Linux服务器安装宝塔服务器管理控制面板
  11. java api 第一个类是_java_8_第一个API
  12. Java编程的11个特点
  13. word图片自动生成域
  14. 在 ubuntu 的桌面上创建快捷方式
  15. 神调侃!程序员专属成长书单,我比女朋友更了解你!
  16. win7系统怎么查看电脑配置,win7电脑系统配置查看
  17. php continue什么意思,php switch continue 什么意思??
  18. Verilog数字系统设计——数字时钟(带暂停和任意位置位)
  19. 网管型工业交换机的应用优势
  20. 基于单片机的功放protues_基于Proteus的音频放大器电路设计与仿真详解.doc

热门文章

  1. 【电气专业知识问答】问:什么叫组合电器?什么是GIS?
  2. ajax资料收集-Ajax文章(教程和实例)---Ajax资源下载(源码和教程)---Ajax规范标准
  3. 苹果手机免越狱群控无需硬件即插即用高清投屏控制操作
  4. 航班动态查询接口 支持最新航班查询
  5. 适合普通人的108个短视频项目:不用出镜也能赚钱的手机摄影玩法(3)
  6. portal服务器信息超时,某学校Agile Controller-Campus(V100R003C50SPC300)作为portal服务器用户反映认证通过后一定时间内掉线需重新认证问题排查...
  7. java多线程 注意事项_多线程使用及注意事项
  8. 类似于陌陌点点和探探首页切换效果
  9. 如何群发邮件?群发邮件让发收件人互相不知道?邮箱群发邮件技巧
  10. 大部分有高学历的人比低学历的人强