现象:
purge recyclebin之后dba_segments仍然有BIN$段。

如下,执行了purge recyclebin之后:

SQL> select segment_name,SEGMENT_TYPE from dba_segments where tablespace_name like 'USERS' and owner='ZHOU186'

 2 ;

SEGMENT_NAME SEGMENT_TYPE

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

BIN$xd87Y+adofPgQAB/AQB9yA==$0 TABLE

BIN$xd87Y+acofPgQAB/AQB9yA==$0 TABLE

ZHOU_WORK_UNITE_??? TABLE

ZHOU_WORK_UNITE_??? TABLE

ZHOU_WORK_UNITE_?? TABLE

BIN$0QhC65ubuMzgQAB/AQBaBg==$0 TABLE

ZHOU_WORK_UNITE_??? TABLE

ZHOU_WORK_UNITE_??? TABLE

BIN$wJ9k2G65qpDgQAB/AQAj+g==$0 TABLE

ZHOU_WORK_UNITE_??? TABLE

BIN$0QhC65uauMzgQAB/AQBaBg==$0 TABLE

ZHOU_WORK_UNITE_??? TABLE

BIN$0QhC65uduMzgQAB/AQBaBg==$0 TABLE

BIN$0QhC65ucuMzgQAB/AQBaBg==$0 TABLE

SQL> desc ZHOU186."BIN$xd87Y+adofPgQAB/AQB9yA==$0";

 Name Null? Type

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

 BEGIN_DATE VARCHAR2(10)

 BEGIN_TIME VARCHAR2(10)

 END_DATE VARCHAR2(10)

 END_TIME VARCHAR2(10)

 POSITION1 VARCHAR2(30)

 PRG_NUM VARCHAR2(30)

 WORK_TIME FLOAT(126)

 FIRST_CHECK NUMBER(38)

 PERSON_NUMBER VARCHAR2(20)

 JOB_BIN VARCHAR2(20)

 JOB_BINNUMBER NUMBER(38)

分析:

客户的操作步骤大致是:

[oracle@MESZHOUDB ~]$ sqlplus / as sysdba

SQL*Plus: Release 10.2.0.4.0 - Production on Thu May 16 09:55:40 2013

Copyright (c) 1982, 2007, Oracle. All Rights Reserved.

Connected to:

Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL>

SQL> alter session set current_schema=ZHOU186;            <====注意到是set current_schema,并不是直接登录进来

Session altered.

SQL> purge recyclebin;

Recyclebin purged.

SQL>

SQL>

SQL> select segment_name from dba_segments where tablespace_name like 'USERS' and owner='ZHOU186'

 2 ;

SEGMENT_NAME

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

BIN$xd87Y+adofPgQAB/AQB9yA==$0

BIN$xd87Y+acofPgQAB/AQB9yA==$0

ZHOU_WORK_UNITE_???

ZHOU_WORK_UNITE_???

ZHOU_WORK_UNITE_??

BIN$0QhC65ubuMzgQAB/AQBaBg==$0

ZHOU_WORK_UNITE_???

ZHOU_WORK_UNITE_???

BIN$wJ9k2G65qpDgQAB/AQAj+g==$0

ZHOU_WORK_UNITE_???

BIN$0QhC65uauMzgQAB/AQBaBg==$0

SEGMENT_NAME

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

ZHOU_WORK_UNITE_???

BIN$0QhC65uduMzgQAB/AQBaBg==$0

BIN$0QhC65ucuMzgQAB/AQBaBg==$0

BIN$0QhC65ueuMzgQAB/AQBaBg==$0

ZHOU_WORK_UNITE_???

BIN$w2uuBw1tJa/gQAB/AQB7Eg==$0

BIN$w2uuBw1sJa/gQAB/AQB7Eg==$0

BIN$w2uuBw1uJa/gQAB/AQB7Eg==$0

BIN$w2uuBw1vJa/gQAB/AQB7Eg==$0

Oracle文档的说明:

The CURRENT_SCHEMA parameter changes the current schema of the session to the specified schema. Subsequent unqualified references to schema objects during the session will resolve to objects in the specified schema.

This setting offers a convenient way to perform operations on objects in a schema other than that of the current user without having to qualify the objects with the schema name. This setting changes the current schema, but it does not change the session user or the current user, nor does it give the session user any additional system or object privileges for the session.

For example:

The table "T1" is owned by user "TEST" and user "SCOTT" doesn't have a table named "T1":

SQL>CONNECT TEST/TEST

SQL>GRANT SELECT ON T1 TO SCOTT;

SQL>CONNECT scott/tiger

SQL>SELECT * FROM SCOTT.T1; <<<<< you must specify the table prefix "SCOTT."

SQL>ALTER SESSION SET CURRENT_SCHEMA = test;

SQL>SELECT * FROM T1; <<<<< Now you need not to add the prefix "SCOTT."

After the session set CURRENT_SCHEMA = test, the only change is that the user "SCOTT" can access the table "TEST.T1" without specifying the table prefix.

The current user is still "TEST", This time when you perform a "purge recyclebin", it just purges the recyclebin in user "TEST", not "SCOTT".

For more details, please refer to:

Oracle? Database SQL Reference

10g Release 2 (10.2)

B14200-02

http://docs.oracle.com/cd/B19306_01/server.102/b14200/statements_2012.htm#SQLRF00901

一句话总结:都是基本概念没过关,很多事情想当然的去理解,Oracle文档还是值得很多人细细的读。

purge recyclebin之后dba_segments仍然有BIN$段的更多相关文章

  1. Oracle 手工清除回滚段的几种方法

    关于回滚段的问题,之前也小整理过一个,参考: Current online Redo 和 Undo 损坏的处理方法 http://blog.csdn.net/tianlesoftware/articl ...

  2. oracle drop table and purge

    一.drop表 执行drop table xx 语句 drop后的表被放在回收站(user_recyclebin)里,而不是直接删除掉.这样,回收站里的表信息就可以被恢复,或彻底清除. 通过查询回收站 ...

  3. 【转】Oracle回收站(recyclebin)

    我们都比较熟悉windows中的回收站,文件删除后放到回收站里还可以再复原.Oracle回收站的原理完全一样,只是实现的细节方面有些差异.另外回收站中只能回收表和相关的对象包括索引.约束.触发器.嵌套 ...

  4. 一个purge参数引发的惨案——从线上hbase数据被删事故说起

    在写这篇blog前,我的心情久久不能平静,虽然明白运维工作如履薄冰,但没有料到这么一个细小的疏漏会带来如此严重的灾难.这是一起其他公司误用puppet参数引发的事故,而且这个参数我也曾被“坑过”.   ...

  5. DROP TABLE ** CASCADE CONSTRAINTS PURGE删除表的时候级联删除从表外键

    1.关于 cascade constraints 假设A为主表(既含有某一主键的表),B为从表(即引用了A的主键作为外键). 则当删除A表时,如不特殊说明,则 drop table A 系统会出现错误 ...

  6. Oracle10g 回收站及彻底删除table : drop table xx purge

    drop后的表被放在回收站(user_recyclebin)里,而不是直接删除掉.这样,回收站里的表信息就可以被恢复,或彻底清除. 1.通过查询回收站user_recyclebin获取被删除的表信息, ...

  7. oracle Recyclebin

    每个用户都有自己的Recycle Bin.删除的对象不会永久存储在Recycle Bin中,Oracle会按照一定的规则自动清除里面的内容,如没有足够的空间.执行show recyclebin时只列出 ...

  8. oracle recyclebin详解(闪回删除的表)

    今天在SOA应用数据库上运用DBMS_REDEFITION包进行在线非分区表转换分区表操作时,本想DROP掉建的临时表cube_scope_temp不小心后面忘记加"temp"直接 ...

  9. ORACLE Recyclebin管理及flashback recyclebin中的对象

    Flashback用于恢复用户误删除的对象(包括表,索引等), 不支持sys用户. system表空间下的对象,也不能从回收站里拿到.故使用SYS 或者SYSTEM用户登陆时, show recycl ...

随机推荐

  1. PLSQL Developer删除奇葩表出现异常ORA-00942: 表或试图不存在

    简单描述一下问题:发现数据库里有两个名称相同的表,不同的是PLSQL Developer里一个表名显示是大写,而另一个表名显示是小写 一般情况下,无论建表语句是大写,还是小写,因Oracle是区分大小 ...

  2. DbHelper.ttinclude 更新,查询视图和表

    <#+ public class DbHelper { #region GetDbTables public static List<DbTable> GetDbTables(str ...

  3. iPhone 配置使用工具

    “iPhone 配置实用工具”可让您轻松地创建.维护和安装配置描述文件及对配置描述文件进行加密,跟踪和安装预置描述文件与授权的应用程序,以及采集包括控制台日志在内的设备信息. http://suppo ...

  4. Memcached存储机制

    Memcached存储机制 memcached 内存管理 分析(转) 缓存.缓存算法和缓存框架简介 memcached全面剖析–PDF总结篇

  5. CSDN极客头条使用指南

    CSDN极客头条使用指南 今天给大家介绍一下CSDN博客最新推出的这个栏目--CSDN极客头条. 极客头条是什么 极客头条大家分享优质IT资源的聚集地. 大家不仅能够分享CSDN的文章,更能够将其它社 ...

  6. AngularJS.directive系列:嵌套directive的通讯及scope研究

    一.directive中的scope directive无疑是AngularJS中比较复杂难懂的部分,而directive中个scope更是其中最复杂的部分了,尤其是在嵌套directive中互相通讯 ...

  7. QT编译错误:Project ERROR: This example requires Qt to be configured with -opengl desktop

    学习QT场景视图,对一个Boxes的例子比较感兴趣,于是去编译学习,结果编译不能通过(使用的是QT5.12): Project ERROR: This example requires Qt to b ...

  8. JVM垃圾回收机制之引用类型

    一:引用的类型 javac编译器编译源文件后,生成字节码文件,在类加载器加载字节码文件到内存中时,在内存中开辟 空间,栈.堆以及方法区,来存放对象以及引用.引用可以分为四种: 强引用:平常我们在编写程 ...

  9. 跨域、跨服务器调用时候session丢失的问题

    最近新进一个公司,做的项目是手机支付系统.由于涉及到金钱相关的,所以安全性要求特别的高.项目分了很多个子系统,在部署(测试)的时候是每个Tomcat上面只放一个子系统.比如现在有5个子系统,那么就会对 ...

  10. 泛泰A870K去掉相机快门声音的方法

    首先ROOT手机,挂载读写,/system/media/audio/ui里面哈,把camera-click.ogg改成camera-click.ogg.bak就可以了 转载自:http://bbs.9 ...