1. create or replace procedure drop_all as
  2.  
  3. cursor cur_obj is
  4.  
  5. select uo.OBJECT_NAME, uo.OBJECT_TYPE
  6.  
  7. from user_objects uo
  8.  
  9. where uo.OBJECT_NAME not in ('DROP_ALL')
  10.  
  11. and uo.OBJECT_TYPE not in ('LOB');
  12.  
  13. /* cursor cur_tablespace is
  14.  
  15. select ut.TABLESPACE_NAME
  16.  
  17. from user_tablespaces ut
  18.  
  19. where ut.TABLESPACE_NAME not in
  20.  
  21. ('SYSTEM', 'SYSAUX', 'UNDOTBS1', 'TEMP', 'USERS');*/
  22.  
  23. v_obj_name user_objects.OBJECT_NAME%type;
  24.  
  25. v_obj_type user_objects.OBJECT_TYPE%type;
  26.  
  27. /* v_tablespaces_name user_tablespaces.TABLESPACE_NAME%type;*/
  28.  
  29. sql_str1 varchar2();
  30.  
  31. /* sql_str2 varchar2(2000);*/
  32.  
  33. begin
  34.  
  35. open cur_obj;
  36.  
  37. loop
  38.  
  39. fetch cur_obj
  40.  
  41. into v_obj_name, v_obj_type;
  42.  
  43. exit when cur_obj%notfound;
  44.  
  45. sql_str1 := 'drop ' || v_obj_type || ' ' || v_obj_name;
  46.  
  47. execute immediate sql_str1;
  48.  
  49. end loop;
  50.  
  51. close cur_obj;
  52.  
  53. /* open cur_tablespace;
  54.  
  55. loop
  56.  
  57. fetch cur_tablespace
  58.  
  59. into v_tablespaces_name;
  60.  
  61. exit when cur_tablespace%notfound;
  62.  
  63. sql_str2 := 'drop tablespace ' || v_tablespaces_name ||
  64.  
  65. ' including contents';
  66.  
  67. execute immediate sql_str2;
  68.  
  69. end loop;
  70.  
  71. close cur_tablespace;*/
  72.  
  73. end drop_all;
  74.  
  75.   这个存储过程可以一把删掉用户下几乎所有的对象。注释里的东西释放出来就能删除表空间了。这个过程不能回滚,绝对不要在生产环境或者有用的环境上使用。我不对这个过程执行的结果负任何责任。
  76.  
  77. 这个脚本适合在那种删除用户不是很方便的时候使用。
  78.  
  79. 更简单的办法就是删掉用户再重建用户。

Oracle 如何删除掉一个用户下的所有对象的更多相关文章

  1. 如何杀掉一个用户下的所有进程并drop掉这个用户

    如何杀掉一个用户下的所有进程并drop掉这个用户 Copy the sample code below into a file named kill_drop_user.sql.Open SQL*Pl ...

  2. ORACLE无法删除当前连接用户

    今天在做Oracle数据库是遇到ORACLE无法删除当前连接用户 ,经查找可用如下方法解决 . 在Oracle中删除用户时提示:ORACLE无法删除当前连接用户  可以用以下语句    Sql代码   ...

  3. oracle impdp将导出用户的所有对象导入至另一个用户下,生成的触发器语句问题处理

    问题产生的操作步骤及详细说明: 1)操作的数据库是oracle 11g,先通过命令将用户GAS_NEW的数据导出,命令语句如下: expdp GAS_NEW/GAS_NEW@ORCL schemas= ...

  4. oracle "记录被另一个用户锁定"

    出现的原因是有人对某一条数据进行了修改,oracle会通过这个事务记住这条数据,若修改的人没有进行提交或进行回滚记录,oracle是不允许对这条数据在此进行修改的,在这种情况下你要进行修改数据,则会被 ...

  5. Oracle开发:创建一个用户并分配表空间和分配权限

    -- 创建一个用户并分配表空间和分配权限 -- 以sysdba登录 oracle@sha-col-oracle-2:~> sqlplus / as sysdba SQL*Plus: Releas ...

  6. KingbaseES 如何把一个schema下的所有对象访问权限授权给其他用户

    用户需求:新建一个用户 B,需要能够查询A用户的所有表,并且对以后新建的表也要有select权限. 问题分析:对于现有的表可以通过动态sql批量进行授权,但是未来新建的表要如何进行授权呢? 查询了帮助 ...

  7. 转 Oracle 12C 之 CDB/PDB用户的创建与对象管理

    在Oracle 12C中,账号分为两种,一种是公用账号,一种是本地账号(亦可理解为私有账号).共有账号是指在CDB下创建,并在全部PDB中生效的账号,另一种是在PDB中创建的账号. 针对这两种账号的测 ...

  8. 【Oracle】如何让一个用户能够访问另外一个用户下所有的表

    根据需求的不同,也分为好几种方法,且看下文. 先构造基本的环境:创建两个用户AA,BB,基本需求为用户AA能够访问用户BB下所有的表,即用户AA有对BB下所有的表有"select on&qu ...

  9. oracle 删除某个用户下的所有对象

    先存放好dropobj.sql 文件 然后登录需要删除的用户 删除前最好备份一下:(备份是在cmd中进行的) C:\Users\panfu>exp file=d:\expall.dmp log= ...

随机推荐

  1. 简要分析unity3d中剪不断理还乱的yield

    在学习unity3d的时候非常easy看到以下这个样例: void Start () { StartCoroutine(Destroy()); } IEnumerator Destroy(){ yie ...

  2. 使用ionic3快速开发webapp(一)

    Ionic可以让我们使用web技术快速构建接近原生体验的跨平台移动应用. 一.安装ionic 1.需要先安装 Node.js(版本8.x之上): 2.安装cordova 和 ionic: $ npm ...

  3. (七)RabbitMQ消息队列-通过fanout模式将消息推送到多个Queue中

    原文:(七)RabbitMQ消息队列-通过fanout模式将消息推送到多个Queue中 前面第六章我们使用的是direct直连模式来进行消息投递和分发.本章将介绍如何使用fanout模式将消息推送到多 ...

  4. [Recompose] Show a Spinner While a Component is Loading using Recompose

    Learn how to use the 'branch' and 'renderComponent' higher-order components to show a spinner while ...

  5. Java解惑八:很多其它库之谜

    本文是依据JAVA解惑这本书,做的笔记. 电子书见:http://download.csdn.net/detail/u010378705/7527721 谜题76 将线程的启动方法start(),写成 ...

  6. mysql 按日期分组

    select DATE_FORMAT(NOW(),'%Y%m%d') days,count(caseid) count from tc_case group by days; //date_forma ...

  7. 第一次使用docker for windows 遇到的坑

    原文:第一次使用docker for windows 遇到的坑 1. 目前win10安装docker, 不需要安装其他工具,可直接到官网下载 2. 此版本的docker可同时运行Windows con ...

  8. [GraphQL] Write a GraphQL Mutation

    In order to change the data that we can query for in a GraphQL Schema, we have to define what is cal ...

  9. Android UI:看看Google官方自定义带旋转动画的ImageView-----RotateImageView怎么写(附 图片淡入淡...)

    众所周知,想要让ImageView旋转的话,可以用setRotation()让其围绕中心点旋转,但这个旋转是不带动画的,也就是旋转屏幕时图片噌的一下就转过去了,看不到旋转的过程,此UI体验不大好,为此 ...

  10. js进阶 11-13 jquery如何包裹元素和去除元素外的包裹

    js进阶 11-13  jquery如何包裹元素和去除元素外的包裹 一.总结 一句话总结:wrap().wrapAll().unwrap().innerWrap()四个方法 1.jquery中unwr ...