Oracle 删除用户下的所有用户对象

2014-11-24 18:17:51 · 作者: · 浏览: 0

网上搜索了些资料,也得到了些启发:用户数据对象是可以集中管理的,可以通过select 查出和过滤用户对象,然后一一删除即可。麻烦是麻烦了些,总归是有解决方案的。解救办法如下:


select o.OBJECT_NAME,o.OBJECT_TYPE,o.CREATED,o.LAST_DDL_TIME from user_objects o


该语句是查出当前用户的所有用户对象的名称,类型,创建时间和修改时间结果如下图:



有了这几个字段,就可以做几件事了:1,可以根据导入备份的时间来筛选出需要删除的数据对象。2,根据类型可以分别筛选出不同的数据对象。3,根据名称可以拼接出不同的drop语句。例如:拼接出drop语句


select 'drop '|| o.OBJECT_TYPE||' ' ||o.OBJECT_NAME from user_objects o where to_char(o.LAST_DDL_TIME,'yyyy-mm-dd')>='2013-01-10'


这条语句是根据时间过滤出符合条件的数据对象名称和类型,拼接出drop语句,查询结果如下图:



这样所有的数据对象都拼接上了drop,把这些都拷贝到文本编辑器里,看一看有没有多余的东西,替换成空,然后拿到命令行下去执行。


这样就可以把大部分数据对象都删掉了,有些需要手动去删,反复执行上面的操作也可以,但有一个lob类型的是不能采用这种方式删的,所以需要想另外的办法。


这样折腾一段时间,应该就可以完成了,主要是TYPE,这个类型很顽固,不但不好删除,而且还影响其他用户。所以一定要手动删除掉。