在oracle存储过程中创建临时表
在oracle的存储过程中,不能直接使用DDL语句,比如create、alter、drop、truncate等。
那如果我们想在存储过程中建立一张临时表就只能使用动态sql语句了:
- create or replace procedure pro as
- str_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;
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存储过程中创建临时表相关推荐
- java 创建临时表 oracle_在ORACLE存储过程中创建临时表
在ORACLE存储过程中创建临时表 存储过程里不能直接使用DDL语句,所以只能使用动态SQL语句来执行 --ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后ORACLE将截 ...
- oracle临时表教程,在oracle存储过程中创建临时表
在oracle的存储过程中,不能直接使用DDL语句,比如create.alter.drop.truncate等. 那如果我们想在存储过程中建立一张临时表就只能使用动态sql语句了: create or ...
- mysql语句创建临时表并存入数据_mysql实例:在存储过程中创建临时表并储存数据...
在mysql存储过程中创建临时表,并保存数据到该表,然后根据存储过程调用的例子. 是学习mysql存储过程的好例子,值得参考. 代码: mysql> mysql> CREATE TABLE ...
- oracle数据存入临时表,oracle中创建临时表步骤
当前位置:我的异常网» 数据库 » oracle中创建临时表步骤 oracle中创建临时表步骤 www.myexceptions.net 网友分享于:2014-06-08 浏览:4次 oracle ...
- mysql 存储过程临时表_在MySQL存储过程中创建的临时表的范围
问题撤销!当我拼写正确的一切,问题消失了! 我有一个MySQL存储过程创建一个临时表.当我从mysql提示符调用过程时,它似乎运行成功,但是如果我从临时表中选择COUNT(*),我会收到一个错误,表示 ...
- mysql 过程 临时表_在存储过程mysql中创建临时表
我有SQL Server的经验.这是我第一次使用mysql.我想在存储过程中创建一个临时表.我不知道我在这里错过了什么. 我想做的是: 循环遍历事件及其匹配项,并将这些匹配项插入到临时表中,然后从该临 ...
- Oracle存储过程中异常Exception的捕捉和处理
Oracle存储过程中异常的捕捉和处理 CREATE OR REPLACE Procedure Proc_error_process ( v_IN in Varchar2, v_OUT Out Var ...
- Oracle数据库中的临时表
概述 写这篇文章的起因,是由于客户存在这样的场景.每次登录时,需要创建一些临时表(业务上临时),然后插入一些数据,返回到客户端,然后删除这些表.最初用户用的是普通表,带来很大的开销.后来改为Globa ...
- oracle存储过程ddl,Oracle 存储过程中的DDL语句
Oracle的存储过程,是我们使用数据库应用开发的重要工具手段.在存储过程中,我们大部分应用场景都是使用DML语句进行数据增删改操作.本篇中,我们一起探讨一下数据定义语句DDL在存储过程中使用的细节和 ...
最新文章
- Sampling Procedure 和 Sample-drawing Procedure, SAP QM里的双胞胎?
- 腐蚀单机怎么进_华强北淘来的iPhone6S,进水后严重腐蚀,小伙飞线拯救又赚到了!...
- 01:初识Redis
- Shell脚本实战之文件批量创建和修改
- HTTP 协议的三次握手
- php操作外部文件,php文件操作-将其他文件的数据添加到本文件中
- complementary prior
- 来做网课老师不?年薪两百万,上不封顶...
- python如何保存图像_Python应用引擎:如何保存图像?
- Linux服务器安装宝塔面板,Linux服务器安装宝塔服务器管理控制面板
- java api 第一个类是_java_8_第一个API
- Java编程的11个特点
- word图片自动生成域
- 在 ubuntu 的桌面上创建快捷方式
- 神调侃!程序员专属成长书单,我比女朋友更了解你!
- win7系统怎么查看电脑配置,win7电脑系统配置查看
- php continue什么意思,php switch continue 什么意思??
- Verilog数字系统设计——数字时钟(带暂停和任意位置位)
- 网管型工业交换机的应用优势
- 基于单片机的功放protues_基于Proteus的音频放大器电路设计与仿真详解.doc
热门文章
- 【电气专业知识问答】问:什么叫组合电器?什么是GIS?
- ajax资料收集-Ajax文章(教程和实例)---Ajax资源下载(源码和教程)---Ajax规范标准
- 苹果手机免越狱群控无需硬件即插即用高清投屏控制操作
- 航班动态查询接口 支持最新航班查询
- 适合普通人的108个短视频项目:不用出镜也能赚钱的手机摄影玩法(3)
- portal服务器信息超时,某学校Agile Controller-Campus(V100R003C50SPC300)作为portal服务器用户反映认证通过后一定时间内掉线需重新认证问题排查...
- java多线程 注意事项_多线程使用及注意事项
- 类似于陌陌点点和探探首页切换效果
- 如何群发邮件?群发邮件让发收件人互相不知道?邮箱群发邮件技巧
- 大部分有高学历的人比低学历的人强