首页 >数据库 >mysql教程 >ORA-14452错误解决方法

ORA-14452错误解决方法

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原创
2016-06-07 17:17:082628浏览

最近工作中创建了一张session级的临时表,删除的时候报下面错误:ORA-14452:试图创建,更改或删除正在使用的临时表中的索引,先从

最近工作中创建了一张session级的临时表,删除的时候报下面错误:ORA-14452:试图创建,更改或删除正在使用的临时表中的索引

网上查阅资料解决方法如下:

1、先从user_objects或dba_objects中查询到该表的object_id:

此处以sysdba登录:
C:Documents and SettingsAdministrator>sqlplus sys/Oracle@orcl as sysdba

SQL> select object_id from dba_objects where object_name=UPPER('RP_RETAIL001');

 OBJECT_ID
----------
     74317

2、根据查到的object_id知道使用该表的session:

SQL> set linesize 1000
SQL> select * from v$lock where id1=74317;

ADDR             KADDR                   SID TY        ID1        ID2      LMODE    REQUEST      CTIME      BLOCK
---------------- ---------------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------
000007FFC70967C0 000007FFC70967E0        166 TO      74317          1          3          0        424          0

3、在从v$session视图中查到该session的SID和SERIAL#:

SQL> select serial# from v$session where sid=166;

   SERIAL#
----------
     51595

4、杀掉这些进程:

SQL> alter system kill session '166,51595';

系统已更改。

5 最后以普通用户登录,删除临时表:

SQL> conn dylan/abc123@orcl
已连接。
SQL> drop table rp_retail001;

表已删除。

-------------------------------------------
made by dylan.

ORA-14452错误解决方法

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn