ORA-14452错误解决方法

最近工作中创建了一张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.

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值