最近工作中创建了一张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.
本文介绍了解决Oracle数据库中无法删除的session级临时表的方法。通过查询对象ID,找到锁定该表的会话,然后杀死相关进程,最终成功删除临时表。
1081

被折叠的 条评论
为什么被折叠?



