最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

ORA-14450:attempttoaccessatransactionaltemptablealre

来源:动视网 责编:小采 时间:2020-11-09 10:33:16
文档

ORA-14450:attempttoaccessatransactionaltemptablealre

ORA-14450:attempttoaccessatransactionaltemptablealre:开发人员告诉我在使用基于事物的临时表的时候报了下面错误:ORA-14450: attempt to access a transactional temp table already 开发人员告诉我在使用基于事物的临时表的时候报了下面错误:ORA-14450: attempt to access a
推荐度:
导读ORA-14450:attempttoaccessatransactionaltemptablealre:开发人员告诉我在使用基于事物的临时表的时候报了下面错误:ORA-14450: attempt to access a transactional temp table already 开发人员告诉我在使用基于事物的临时表的时候报了下面错误:ORA-14450: attempt to access a


开发人员告诉我在使用基于事物的临时表的时候报了下面错误: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 归档日志过大导致无法存储的解决办法

文档

ORA-14450:attempttoaccessatransactionaltemptablealre

ORA-14450:attempttoaccessatransactionaltemptablealre:开发人员告诉我在使用基于事物的临时表的时候报了下面错误:ORA-14450: attempt to access a transactional temp table already 开发人员告诉我在使用基于事物的临时表的时候报了下面错误:ORA-14450: attempt to access a
推荐度:
标签: at to ora
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top