偷得浮生半桶水(半日闲), 好记性不如抄下来(烂笔头). 信息爆炸的时代, 学习是一项持续的工作.
全部博文(1748)
分类:
2009-12-17 11:20:54
当在数据库中创建用户时,基于应用性能和管理方面的考虑,最好为不同的用户创建独立的表空间。
1.创建表空间
不论是linux环境,还是windows环境,都要首先创建好表空间的存放路径,如:
/opt/oracle/oradata/cocis 或 D:"oracle"oradata"cocis
若事先不创建该目录路径,则在创建表空间的时候会出错。
然后执行如下命令:
SQL> create tablespace cocis
2 datafile 'D:"oracle"oradata"cocis"cocis01.dbf'
3 size 100M AutoExtend On Next 10M Maxsize 2048M
4 extent management local uniform size 128K
5 segment space management auto
6 /
表空间已创建。
2.为应用创建用户
创建用户的同时,为用户指定缺省的永久表空间和临时表空间。
SQL> create user cocis identified by cocis
2 default tablespace cocis
3 temporary tablespace temp;
用户已创建。
查看用户
SQL> select username,default_tablespace,temporary_tablespace
2 from dba_users
3 where username='COCIS';
USERNAME DEFAULT_TABLESPACE TEMPORARY_TABLESPACE
------------------------------ ------------------------------ ------------------
COCIS COCIS TEMP
SQL> select username,user_id,password,default_tablespace,temporary_tablespace
2 from dba_users
3 where username='COCIS';
USERNAME USER_ID PASSWORD TEMPORARY_TABLESPACE
------------------------------ ---------- ------------------------------ -----------------------
COCIS 61 E031F623C0F15D34 COCIS
3.权限的授予
SQL> grant connect,resource to cocis;
授权成功。
注释:当用户创建之后,一般只需要授予CONNECT和RESOURCE这两个角色即可。若要单独进行授权,则需执行单独的授权命令,如grant create table to cocis;等。
SQL> revoke unlimited tablespace from cocis;
撤销成功。
SQL> alter user cocis quota unlimited on cocis;
用户已更改。
注释:为了更严谨的管理,可以回收用户的UNLIMITED TABLESPACE权限,然后对用户的空间限额进行单独授权。
-----------------------------------------------------------------------------------------
查看表空间使用情况
select df.tablespace_name "表空间名",totalspace "总空间M",freespace "剩余空间M",round((1-freespace/totalspace)*100,2) "使用率%"
from
(select tablespace_name,round(sum(bytes)/1024/1024) totalspace
from dba_data_files
group by tablespace_name) df,
(select tablespace_name,round(sum(bytes)/1024/1024) freespace
from dba_free_space
group by tablespace_name) fs
where df.tablespace_name=fs.tablespace_name;