语句如下:
create [smallfile | bigfile] [permanent | undo | temporary ] tablespace tbname
datafile | tempfile datafile_clause1 [,datafile_clause2,……]-->数据文件字句
[logging | nologging] –>
[extent mangement dictionary | local] –>区的管理方式字典或本地管理,oralce已经淘汰了字典管理方式。
[autoallocate | uniform [size integer [k | m]]] -->local-managed tablespace的2个表空间区的分配方式。
[default storge clause] -->dictionary-managed tablespace的默认存储参数字句。这两条语句不能共存。
[segment space management auto | manual] -->段的管理方式,manual是为兼容之前版本设置的,默认auto。
[blocksize integer [K | M]
[minimum extent integer [K | M]] -->区的最小大小,数据块的整数倍。
[online | offline [normal | temporary | immediate | for recover]] ;
注:
bigfile是Oralce10g新引进的表空间,只能放置一个数据文件(或临时文件),其数据文件可以包含4G个数据块,按照一个数据块为8K,那么大文件表空间容量就是32Tb。
smallfile就是和bigfile相对而言的了,就是之前的那些表空间,例如system、sysaux等成为小文件表空间。datafile_clause1的语法如下:
'path_filename_suffix’ size integer [K | M] -->必须是绝对路径 [reuse] [autoextend off | on] -->自动扩展是否允许 [next integer [K | M]] [maxsize unlimited | integer [K | M]] -->使用无限制大小还是指定大小local-managed tablespace(本地管理方式)的2个表空间的区的分配方式:
autoallocate(自动分配),由oracle自动管理,是默认的。 uniform(统一分配),指定表空间中所有区的大小相同,区的大小默认是1M,也可以手工指定该大小。不能在undo中使用。storge clause的语法如下:
storage (initial integer [K | M] -->initial指定第一个区的大小,next指定下一个区及以后的区的大小。 next integer [K | M] –>initial默认是5个数据块的大小,next的最小值是1个数据块大小。 pctincrease integer -->指定第三个区之后及后续区在前面区的基础上增加的百分比。 minextents integer maxextents {integer | unlimited})-->用无限制大小还是指定大小
permanent(永久表空间):除了undo(撤销表空间),相对于temporary而言,其他的表空间都是永久表空间。
temporary(临时表空间):当出现(order by)排序、group by(分组汇总)、create index(索引)等操作时,会产生大量的临时数据,这些数据的存放地方就会使用临时表空间。
temp表空间可以建立多个,每个用户可以使用不同的temp表空间。若在创建用户时没有为用户指定一个临时表空间,Oralce会默认使用system表空间创建临时段,存放临时数据。
undo(撤销表空间):该表空间的作用可以查看本博客的另一篇文章。
undo表空间可以创建多个,但是同时只能有一个处于激活状态,建立多个就是浪费磁盘存储空间,完全可以把undo建立的大一点。