视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle删除用户下的所有用户对象
2020-11-09 10:55:12 责编:小采
文档


使用PL/SQL Developer恢复备份时,不小心把备份恢复到了system用户下,居然不出任何意外的成功了。而这时候我的心都碎了,大家知

犯了一个错误,使用PL/SQL Developer恢复备份时,不小心把备份恢复到了system用户下,居然不出任何意外的成功了。而这时候我的心都碎了,大家知道system是Oracle的超级管理员之一,仅次于sys用户,是管理次一级的系统对象和用户对象的管理员,不能够删除和重建,然而那么多数据导进去了,怎么清楚掉呢?

网上搜索了些资料,也得到了些启发:用户数据对象是可以集中管理的,可以通过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,这个类型很顽固,,不但不好删除,而且还影响其他用户。所以一定要手动删除掉。

下载本文
显示全文
专题