Oracle 10g数据库中,当在数据库中创建用户时,基于应用性能和管理方面的考虑,最好为不同的用户创建独立的表空间。 那么创建表空间的步骤是怎样实现的呢?本文我们主要就介绍了这一部分内容,接下来就让我们一起来了解一下这部分内容吧。
1.创建表空间
不论是Lnux环境,还是Wndows环境,都要首先创建好表空间的存放路径,根据自己的情况修改。如:/opt/oracle/oradata/cocis 或 D:\oracle\oradata\cocis,若事先不创建该目录路径,则在创建表空间的时候会出错。
通过pl/sql登录到Oracle数据库上,然后执行菜单:文件/新建/命令窗口 ,打开一个命令窗口然后在该命令窗口中执行脚本创建和删除表空间 。
创建表空间
Sql>createtablespacehistdbdatafile'D:\oracle\product\10.2.0\oradata\orcl\histdb.dbf'size200mautoextendonnext10mmaxsizeunlimited; Sql>alterdatabasedatafile'D:\oracle\product\10.2.0\oradata\orcl\histdb.dbf'autoextendon;
1) DATAFILE: 表空间数据文件存放路径
2) SIZE: 起初设置为200M
3) UNIFORM: 指定区尺寸为128k,如不指定,区尺寸默认为64k
4) 空间名称histdb 与 数据文件名称 histdb.dbf 不要求相同,可随意命名.
5) AUTOEXTEND ON/OFF 表示启动/停止自动扩展表空间
6) alter database datafile ‘ D:\oracle\product\10.2.0\oradata\orcl\histdb.dbf ‘ resize 500m; //手动修改数据文件大小为500M
删除表空间
DROPTABLESPACEhistdbINCLUDINGCONTENTSANDDATAFILES;
表空间已创建。
2.为应用创建用户
创建用户的同时,为用户指定缺省的永久表空间和临时表空间。
SQL>createusercocisidentifiedbycocis 2defaulttablespacecocis 3temporarytablespacetemp; 用户已创建。 SQL>selectusername,default_tablespace,temporary_tablespace 2fromdba_users 3whereusername='COCIS'; USERNAMEDEFAULT_TABLESPACETEMPORARY_TABLESPACE ------------------------------------------------------------------------------ COCISCOCISTEMP SQL>selectusername,user_id,password,default_tablespace,temporary_tablespace 2fromdba_users 3whereusername='COCIS'; USERNAMEUSER_IDPASSWORDTEMPORARY_TABLESPACE --------------------------------------------------------------------------------------------- COCIS61E031F623C0F15D34COCIS
3.权限的授予
SQL>grantconnect,resourcetococis; 授权成功。
注释:当用户创建之后,一般只需要授予CONNECT和RESOURCE这两个角色即可。若要单独进行授权,则需执行单独的授权命令,如grant create table to cocis;等。
如果要授予SYSDBA的权限给用户则用如下命令:
SQL>grantSYSDBAtococis; --------------------------------------------------- SQL>revokeunlimitedtablespacefromcocis; 撤销成功。 SQL>alterusercocisquotaunlimitedoncocis; 用户已更改。
注释:为了更严谨的管理,可以回收用户的UNLIMITED TABLESPACE权限,然后对用户的空间限额进行单独授权。