- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Oracle 删除用户和表空间详细介绍由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Oracle 删除用户和表空间 。
Oracle 使用时间长了, 新增了许多user 和tablespace. 需要清理一下 。
对于单个user和tablespace 来说, 可以使用如下命令来完成.
步骤一: 删除user 。
1
|
drop
user
××
cascade
|
说明: 删除了user,只是删除了该user下的schema objects,是不会删除相应的tablespace的.
步骤二: 删除tablespace 。
1
|
DROP
TABLESPACE tablespace_name INCLUDING CONTENTS
AND
DATAFILES;
|
但是,因为是供开发环境来使用的db, 需要清理的user 和 table space 很多.
思路:
Export出DB中所有的user和tablespace, 筛选出系统的和有用的tablespace,把有用的信息load到一张表中去。然后写例程循环,把不在有用表的tablespace删掉 。
1. select username,default_tablespace from dba_users,
2. 。
1
2
3
4
5
6
7
|
create
table
MTUSEFULSPACE
(
ID Number(4)
NOT
NULL
PRIMARY
KEY
,
USERNAME varchar2(30),
TABLESPACENAME varchar2(60),
OWNERNAME varchar2(30)
);
|
3. 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
declare
icount number(2);
tempspace varchar2(60);
begin
for
curTable
in
(
select
username
as
allusr,default_tablespace
as
alltblspace
from
dba_users)
loop
tempspace :=curTable.alltblspace;
dbms_output.put_line(tempspace);
select
count
(TABLESPACENAME)
into
icount
from
MTUSEFULSPACE
where
TABLESPACENAME = tempspace;
if icount=0
then
DROP
TABLESPACE tempspace INCLUDING CONTENTS
AND
DATAFILES;
end
if;
commit
;
end
loop;
end
;
|
执行后会报如下错误 。
1
2
3
4
5
6
7
8
9
10
11
|
ORA-06550: 第 10 行, 第 5 列:
PLS-00103: 出现符号
"DROP"
在需要下列之一时:
begin
case
declare
exit
for
goto
if loop mod
null
pragma raise
return
select
update
while
with
<an identifier>
<a
double
-quoted delimited-identifier> <a bind variable> <<
close
current
delete
fetch
lock
insert
open
rollback
savepoint
set
sql
execute
commit
forall merge pipe
06550. 00000 -
"line %s, column %s:\n%s"
*Cause: Usually a PL/SQL compilation error.
*
Action
:
|
好像是被锁了。.
没办法,例程不能写,就只能组出语句执行了.
把需要删除的user, tablespace 导出到Excel. 使用CONCATENATE 组出SQL. 。
贴到SQLdevelop 批量执行.
整个删除会比较耗时间, 100多个user. 用了12个小时左右.
如要找datafile的具体位置,可以使用 。
1
|
select
t1.
name
,t2.
name
from
v$tablespace t1, v$datafile t2
where
t1.ts# = t2.ts#;
|
SQL code 。
--删除空的表空间,但是不包含物理文件 。
1
|
drop
tablespace tablespace_name;
|
--删除非空表空间,但是不包含物理文件 。
1
|
drop
tablespace tablespace_name including contents;
|
--删除空表空间,包含物理文件 。
1
|
drop
tablespace tablespace_name including datafiles;
|
--删除非空表空间,包含物理文件 。
1
|
drop
tablespace tablespace_name including contents
and
datafiles;
|
--如果其他表空间中的表有外键等约束关联到了本表空间中的表的字段,就要加上CASCADE CONSTRAINTS 。
1
|
drop
tablespace tablespace_name including contents
and
datafiles
CASCADE
CONSTRAINTS;
|
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! 。
原文链接:http://blog.csdn.net/oscar999/article/details/7468153 。
最后此篇关于Oracle 删除用户和表空间详细介绍的文章就讲到这里了,如果你想了解更多关于Oracle 删除用户和表空间详细介绍的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
在为 Web 应用程序用例图建模时,为用户可以拥有的每个角色创建一个角色是否更好?或拥有一个角色、用户和一个具有特权的矩阵? guest < 用户 < 版主 < 管理员 1: guest 、用户、版主
我无法使用 Elixir 连接到 Postgres: ** (Mix) The database for PhoenixChat.Repo couldn't be created: FATAL 28P
这个问题已经有答案了: Group by field name in Java (7 个回答) 已关闭 7 年前。 我必须编写一个需要 List 的方法并返回 Map> . User包含 Person
感谢您的帮助,首先我将显示代码: $dotaz = "Select * from customers JOIN contracts where customers.user_id ='".$_SESS
我只想向所有用户中的一个用户显示一个按钮。我尝试了 orderByKey() 但没有成功! 用户模型有 id 成员,我尝试使用 orderByChild("id") 但结果相同! 我什至尝试了以下技巧
我们在工作中从 MongoDB 切换到 Postgres,我正在建立一个 BDR 组。 在这一步,我正在考虑安全性并尽可能锁定。因此,我希望设置一个 replication 用户(角色)并让 BDR
export class UserListComponent implements OnInit{ users; constructor(private userService: UserS
我可以使用 Sonata User Bundle 将 FOS 包集成到 sonata Admin 包中。我的登录功能正常。现在我想添加 FOSUserBundle 中的更改密码等功能到 sonata
在 LinkedIn 中创建新应用程序时,我得到 4 个单独的代码: API key 秘钥 OAuth 用户 token OAuth 用户密码 我在 OAuth 流程中使用前两个。 的目的是什么?最后
所以..我几乎解决了所有问题。但现在我要处理另一个问题。我使用了这个连接字符串: SqlConnection con = new SqlConnection(@"Data Source=.\SQLEX
我有一组“用户”和一组“订单”。我想列出每个 user_id 的所有 order_id。 var users = { 0: { user_id: 111, us
我已经为我的Django应用创建了一个用户模型 class User(Model): """ The Authentication model. This contains the u
我被这个问题困住了,找不到解决方案。寻找一些方向。我正在用 laravel 开发一个新的项目,目前正致力于用户认证。我正在使用 Laravels 5.8 身份验证模块。 对密码恢复 View 做了一些
安装后我正在使用ansible配置几台计算机。 为此,我在机器上本地运行 ansible。安装中的“主要”用户通常具有不同的名称。我想将该用户用于诸如 become_user 之类的变量. “主要”用
我正在尝试制作一个运行 syncdb 的批处理文件来创建一个数据库文件,然后使用用户名“admin”和密码“admin”创建一个 super 用户。 到目前为止我的代码: python manage.
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我已在 Azure 数据库服务器上设置异地复制。 服务器上运行的数据库之一具有我通过 SSMS 创建的登录名和用户: https://learn.microsoft.com/en-us/azure/s
我有一个 ionic 2 应用程序,正在使用 native FB Login 来检索名称/图片并将其保存到 NativeStorage。流程是我打开WelcomePage、登录并保存数据。从那里,na
这是我的用户身份验证方法: def user_login(request): if request.method == 'POST': username = request.P
我试图获取来自特定用户的所有推文,但是当我迭代在模板中抛出推文时,我得到“User”对象不可迭代 观看次数 tweets = User.objects.get(username__iexact='us
我是一名优秀的程序员,十分优秀!