时间:2021-07-01 10:21:17 帮助过:23人阅读
SQL> select * from v$tablespace; TS# NAME INCLUD BIGFIL FLASHB ENCRYP ---------- ------------------------------------------------------------ ------------ ------ ------ 0 SYSTEM YES NO YES 1 UNDOTBS1 YES NO YES 2 SYSAUX YES NO YES 4 USERS YES NO YES 3 TEMP NO NO YES
查看每个表空间有哪些数据文件:
SQL> desc dba_data_files; Name Null? Type ----------------------------------------- -------- ---------------------------- FILE_NAME VARCHAR2(513) FILE_ID NUMBER TABLESPACE_NAME VARCHAR2(30) BYTES NUMBER BLOCKS NUMBER STATUS VARCHAR2(9) RELATIVE_FNO NUMBER AUTOEXTENSIBLE VARCHAR2(3) MAXBYTES NUMBER MAXBLOCKS NUMBER INCREMENT_BY NUMBER USER_BYTES NUMBER USER_BLOCKS NUMBER ONLINE_STATUS VARCHAR2(7)
查看详细数据文件:
SQL> select file_name,tablespace_name from dba_data_files; FILE_NAME TABLESPACE_NAME ---------------------------------------------------------------------------------------------------------------- /ora10/product/oradata/ora10/users01.dbf USERS /ora10/product/oradata/ora10/sysaux01.dbf SYSAUX /ora10/product/oradata/ora10/undotbs01.dbf UNDOTBS1 /ora10/product/oradata/ora10/system01.dbf SYSTEM
创建一个表空间:
SQL> create tablespace paul datafile ‘/ora10/product/oradata/ora10/paul01.dbf‘ size 20m; Tablespace created.
查看我们创建的表空间:
[ora10@localhost ora10]$ pwd /ora10/product/oradata/ora10 [ora10@localhost ora10]$ ls control01.ctl control03.ctl redo01.log redo03.log system01.dbf undotbs01.dbf control02.ctl paul01.dbf redo02.log sysaux01.dbf temp01.dbf users01.dbf
表空间根据对区间(extents)的管理分为两种类型
词典管理表空间(Dictionary-managed tablespaces)
在表空间里,有的区间被占用了,有的没被占用,这些数据是放在数据字典里的。当你对这个表空间进行分配或释放的时候,数据文件里相关的表就会做修改。
本地管理表空间(locally managed tablespace)
本地管理表空间不是在数据词典里存储表空间的,由自由区管理的表空间。用位图来自由的管理区间。一个区间对一个位,如果这个位是1表示已经被占用,0表示未被占用。
词典管理空间表示“中央集权治”,本地管理表空间表示“省市自治区”,一个databases表示中国,tablespaces表示一个省或直辖市。词典管理统一由中央调配。而本地管理表示有高度的自治权利,自已各种资源的分配不用上报中央。
Undo tablespace
Undo 类型的表空间,当你对一张表或一条记录进行修改的时候,它会对修改之前的信息进行保存,这样可以保证数据的回滚。Undo 只包含undo类型的对象,不能包含任何其他对象,只适合于数据文件和区间管理。
创建undo 类型的表空间:
SQL>create undo tablespace undo1 datafile ‘/ora10/product/oradata/ora10/paul01.dbf‘ size 20m;
Temporary Tablespaces
临时表空间,相当于一个临时的垃圾场。用于排序操作,比如你要做一次大数据量的查询,但在内存无法存储这么大量的数据,然后会在磁盘上建立一个临时的表空间用记存放这些数据。Oracle就会用这个临时表空间做排序,存储中间结果。
一个全局的临时表空间,可以由多个用户共享,谁需要谁使用。但它只能存放临时的数据,不能包含任何永久性对象。 建议用本地管理方式创建这个表空间。
创建临时表空间:
SQL>create temporary tablespace temp datafile ‘/ora10/product/oradata/ora10/paul01.dbf‘ size 20m extent management local uniform size 4m;
删除表空间:
删除表空间,使用命令drop tablespace ‘表空间名’ 但是有3个选项需要注意:
INCLUDING CONTENTS:指删除表空间中的segments;
INCLUDING CONTENTS AND DATAFILES:指删除segments和datafiles;
CASCADE CONSTRAINTS:删除所有与该空间相关的完整性约束条件。
例:
DROP TABLESPACE FESCO ‘表空间名’ CONTENTS AND DATAFILES CASCADE CONSTRAINTS;
oracle 表空间
标签:概念 user 行修改 clu datafile desc 记录 var rod