您的位置:首页 > 其它

ORA-14452错误解决方法

2012-07-19 09:54 344 查看
最近工作中创建了一张session级的临时表,删除的时候报下面错误:



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

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

此处以sysdba登录:

C:\Documents and Settings\Administrator>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;

表已删除。

6 总结一下:

select 'alter system kill session '''|| a.sid ||',' ||a.SERIAL# ||''''||'immediate;'
from v$session a,v$lock b
where a.sid=b.SID
and b.ID1=(select object_id from dba_objects where object_name=UPPER('RP_VIP_SALE_VIEW'));


-------------------------------------------

made by dylan.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: