浏览 46180 次
锁定老帖子 主题:Oracle 临时表用法
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-04-20
临时表分为SESSION、TRANSACTION两种,SESSION级的临时表数据在整个SESSION都存在,直到结束此次SESSION;而TRANSACTION级的临时表数据在TRANACTION结束后消失,即COMMIT/ROLLBACK或结束SESSION都会清除TRANACTION临时表数据。 两种临时表的语法: create global temporary table 临时表名 on commit preserve|delete rows 用preserve时就是SESSION级的临时表,用delete就是TRANSACTION级的临时表 一、SESSION级临时表 1、建立临时表 create global temporary table temp_tbl(col_a varchar2(30)) on commit preserve rows 2、插入数据 insert into temp_tbl values('test session table') 3、提交commit; 4、查询数据 select *from temp_tbl 可以看到数据'test session table'记录还在。 结束SESSION,重新登录,再查询数据select *from temp_tbl,这时候记录已不存在,因为系统在结束SESSION时自动清除记录 二、TRANSACTION级临时表 1、建立临时表 create global temporary table temp_tbl(col_a varchar2(30)) on commit delete rows 2、插入数据 insert into temp_tbl values('test transaction table') 3、提交 commit 4、查询数据 select *from temp_tbl 这时候可以看到刚才插入的记录'test transaction table'已不存在了;同样,如果不提交而直接结束SESSION,重新登录记录也不存在 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-04-21
大家有什么评价。能对临时表增加其它补充吗?
|
|
返回顶楼 | |