您好,欢迎访问一九零五行业门户网

ORA-14450: attempt to access a transactional temp table alre

开发人员告诉我在使用基于事物的临时表的时候报了下面错误:ora-14450: attempt to access a transactional temp table already
开发人员告诉我在使用基于事物的临时表的时候报了下面错误:
ora-14450: attempt to access a transactional temp table already in use
下面根据实验模拟了2种临时表使用不当报ora-1445o的原因:
1)基于事物的临时表
sql> create global temporary table temp_tab on commit delete rows as select 'a' as a1 from dual;
table created.
sql> select sid from v$mystat where rownum=1;
sid
----------
      191
sql> insert into temp_tab values ('b');
1 row created.
sql>
在191回话不做commit,打开另外一个session 执行ddl(如果在同一会话可以成功执行ddl语句)
sql> alter table temp_tab add b1 varchar2(10);
alter table temp_tab add b1 varchar2(10)
*
error at line 1:
ora-14450: attempt to access a transactional temp table already in use
sql> select sid from v$mystat where rownum=1;
sid
----------
      40
sql>
返回session 191 执行自定义事物
sql> declare
 2  pragma autonomous_transaction;
 3  begin
 4    insert into temp_tab values ('c');
 5    commit;
 6  end;
 7  /
declare
*
error at line 1:
ora-14450: attempt to access a transactional temp table already in use
ora-06512: at line 4
2)基于session 的临时表
sql> drop table temp_tab purge;
table dropped.
sql> create global temporary table temp_tab on commit preserve rows as select 'a' as a1 from dual;
table created.
sql> select sid from v$mystat where rownum=1;
sid
----------
      191
sql> insert into temp_tab values ('a');
1 row created.
sql> alter table temp_tab add b1 varchar2(10);   
alter table temp_tab add b1 varchar2(10)
*
error at line 1:
ora-14450: attempt to access a transactional temp table already in use
sql> select * from temp_tab;
a
-
a
a
sql> commit;
commit complete.
sql> alter table temp_tab add b1 varchar2(10);
alter table temp_tab add b1 varchar2(10)
*
error at line 1:
ora-14450: attempt to access a transactional temp table already in use
上面实验可以看出基于session 的临时表在同一个session内运行一个事物,无论是提交还是未提交都不能做ddl操作
再运行一个事物,不提交到另外一个session做ddl报错同样错误
sql> delete from  temp_tab;
2 rows deleted.
sql> select sid from v$mystat where rownum=1;
sid
----------
      40
sql> alter table temp_tab add b1 varchar2(10);
alter table temp_tab add b1 varchar2(10)
*
error at line 1:
ora-14450: attempt to access a transactional temp table already in use
提交之后,在另外session测试发现还是无法ddl
sql> commit;
commit complete.
退出session,仅有一个会话做ddl
sql> alter table temp_tab add b1 varchar2(10);
table altered.
总结:
a, 基于transaction的临时表在同一个session里面不允许做自定义事物,并且若在一个session里面运行了一条事物未做提交,在另外一个session无法做ddl操作
b, 基于session的临时表若在某一个sesson里面运行了事物,任何session都不运行做ddl包括运行该事物的session
相关阅读:
oracle ora-01555 快照过旧 说明
ora-01078 和 lrm-00109 报错解决方法
ora-01555超长的query duration时间
ora-00471 处理方法笔记
ora-00314,redolog 损坏,或丢失处理方法
ora-00257 归档日志过大导致无法存储的解决办法

其它类似信息

推荐信息