第一种 minextent
alter table tablename deallocate unused;
将hwm以上任何没使用的空间释放
第二种 minextent >hwm 则释放minextents 以上的空间。
假如要释放hwm以上的空间则使用keep 0。
alter table tablesname deallocate unused keep 0;
2 truncate table命令能够将minextent 之上的空间完全释放。
3 只是将hwm移动,释放的空间不会被其他段使用--
第七章 管理用户 要点:
1.建立和管理数据库帐户 2.建立和管理角色role 3.授权和回收权限
4.通过用户来控制资源的利用
Profile:
1》控制资源的占用 2>管理密码
oracle用户管理:
一、创建profile文件。
SQL>Create profile 文件名 limit
FAILED_LOGIN_ATTEMPTS:指定锁定用户的登录失败次数 PASSWORD_LOCK_TIME:指定用户被锁定天数 PASSWORD_LIFE_TIME:指定口令可用天数
PASSWORD_REUSE_TIME:指定在多长时间内口令不能重用
PASSWORD_REUSE_MAX:指定在重用口令前口令需要改变的次数 SESSIONS_PER_USER:限制用户并发会话个数
CPU_PER_SESSION:限制会话所占用的CPU时间(百分之一秒) CPU_PER_CALL:限制每次调用所占用的CPU时间(百分之一秒) CONNECT_TIME:限制会话的总计连接时间(分钟)
IDLE_TIME:限制会话的空闲时间(分钟));
二、创建用户(包括创建角色):
SQL>Create user 用户名 IDENTIFIED BY 口令
Default tablespace 表空间名
TEMPORARY tablespace 临时表空间名 Profile profile文件名
Quota 限制空间大小 on 表空间名; 并给用户授权:
SQL>grant connect ,resource to 用户名;
举例:
-- 创建角色
DROP ROLE ICDYW;
CREATE ROLE ICDYW NOT IDENTIFIED;
GRANT \
GRANT \GRANT \
-- 创建用户
DROP USER ICDMAIN CASCADE;
CREATE USER ICDMAIN IDENTIFIED BY icd DEFAULT TABLESPACE SERVICE_RPT_DAT TEMPORARY TABLESPACE SERVICE_TEMP PROFILE DEFAULT;
GRANT \
GRANT UNLIMITED TABLESPACE TO \
GRANT SELECT ON SYS.V_$MYSTAT TO ICDMAIN; GRANT SELECT ON SYS.V_$SESSION TO ICDMAIN; GRANT SELECT ON SYS.DBA_JOBS TO ICDMAIN;
ALTER USER ICDMAIN DEFAULT ROLE ALL;
三. 改动用户:
一. 修改用户各项参数:(除用户名外其它各项均可以修改) SQL>Alter user 用户名 IDENTIFIED BY 口令
Default tablespace 表空间名
TEMPORARY tablespace 临时表空间名 Profile profile文件名
Quota 限制空间大小 on 表空间名;
将用户加锁:
SQL>Alter user 用户名 ACCOUNT LOCK; - -加锁 ACCOUNT UNLOCK; - -解锁
强制用户修改口令:
SQL>Alter user 用户名 password expire;
四. 删除用户:
用户下没有实体时:
SQL>Drop user 用户名;
用户已创建实体如表和数据时:
SQL>Drop user 用户名 CASCADE; 注意:当前正连接的用户不得删除。 使用CASCADE选项时,用户及实体马上被删除,应再进入数据文件进行物理删除。
五. 监视用户:
查询用户会话信息:(如果有两个用户以同一用户名登录,则可动态查询
SQL>Select username machine , sid , serial # From V$ session;
删除用户会话:
SQL>Alter system kill session 'sid , serial' ;
显示用户的SQL语句:
SQL>Select user _name , SQL _text From V$ open _cursor;
CREATE USER 语句将建立一个用户。当一个用户连接到ORACLE数据库时,它必须被验
证。ORACLE中验证有三种类型:
Database
external
Global
缺省是数据库验证,当用户连接到数据库时,oracle将检测用户是否是数据库的合法用户,并且要提供正确的password.external验证,oracle将只检测用户是否是合法用户,password已经被网络或系统验证了。global验证也是只检测是否是合法用户,password由oraclesecurity server验证。
Database验证用户账号
数据库验证账号是张好的缺省类型,也是最普通的类型。建立一个账号是piyush,口令是welcome的账号,只需执行下面的命令:
CREATE USE piyush IDENTIFIED BY welcome
piyush可以通过下面的语句将口令改变为saraswatt:
ALTER USER piyush IDENTIFIED BY saraswati;
外部验证用户账号
用户账号进入数据库时可以不提供口令,这种情况下代替数据库识别口令的是客户端操作系统。外部验证账号有时也叫OPS$账号,当他们最初在oracle6开始介绍时,oracle账号都有关键字前缀OPS$,这也就是为什么init.ora 参数os_authent_prefix是OPS$--默认特征与oracle6保持一致。os_authent_prefix定义的字符串必须被预处理为用于Oracle外部识别账号的操作系统账号名。创建操作系统用户appl的语句是:
CREATE USER ops$appl IDENTIFIED EATERNALLY
但在通常情况下,os_authent_prefix将被设置为空,像下面这样:
CREATE USER appl IDENTIFIED EATERNALLY
这样效果是一样的,关键字IDENTIFIED EXTERNALLY告诉ORACLE这是一个外部识别账号。
GLOBAL用户账号
GLOBAL类型的用户账号数据库不检测口令,而是由X.509目录服务器检测口令。创建一个GLOBAL类型的用户账号的方法是:
CREATE USER scott IDENTIFIED GLOBALLY AS \ 关键字IDENTIFIED GLOBALLY AS表示建立的是一个GLOBAL类型的用户账号.
创建和更改用户账号
CREATE USER 用于建立用户账号和给用户账号的属性赋值。ALTER USER用于更改用户账号和属性。但CREATE USER语句必须包括用户名和口令。
有部分属性能用CREATER USER和ALTER USER语句设置,下面对是这些的属性具体描述:
给用户分配缺省表空间
表空间(tablespace)是放置表、索引、丛等用户对象的。如果在create user语句中没有包含表空间,那么缺省的是系统表空间。
CREATE USER piyush IDENTIFIED BY saraswati DEFAULTE TABLESPACE user_data;
ALTER USER manoj DEFAULTE TABLESPACE dev1_data;
给用户分配临时表空间
临时表空间,顾名思义是临时存放表、索引等用户对象的临时段。建立方法一样
CREATE USER piyush IDENTIFIED BY saraswati Temporary TABLESPACE user_data;
ALTER USER manoj Temporary TABLESPACE dev1_data;
给用户分配表空间的使用定额
使用定额限制用户在表空间中使用磁盘的数量。定额可以按字节、千字节、兆字节或者无限制来制定。
CREATE USER piyush IDENTIFIED BY saraswati DEFAULT TABLESPACE user_data QUOTA UNLIMITED ON user_data