1.查看表空间使用情况
--查询表空间使用情况
SELECT Upper(F.TABLESPACE_NAME) "表空间名",
D.TOT_GROOTTE_MB "表空间大小(M)",
D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",
To_char(Round(( D.TOT_GROOTTE_MB - F.TOTAL_BYTES ) / D.TOT_GROOTTE_MB * 100, 2), '990.99')
|| '%' "使用比",
F.TOTAL_BYTES "空闲空间(M)",
F.MAX_BYTES "最大块(M)"
FROM (SELECT TABLESPACE_NAME,
Round(Sum(BYTES) / ( 1024 * 1024 ), 2) TOTAL_BYTES,
Round(Max(BYTES) / ( 1024 * 1024 ), 2) MAX_BYTES
FROM SYS.DBA_FREE_SPACE
GROUP BY TABLESPACE_NAME) F,
(SELECT DD.TABLESPACE_NAME,
Round(Sum(DD.BYTES) / ( 1024 * 1024 ), 2) TOT_GROOTTE_MB
FROM SYS.DBA_DATA_FILES DD
GROUP BY DD.TABLESPACE_NAME) D
WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME
ORDER BY 使用比 desc;
2.查看数据文件路径
SELECT FILE_ID, FILE_NAME, TABLESPACE_NAME, AUTOEXTENSIBLE, INCREMENT_BY
FROM DBA_DATA_FILES
WHERE TABLESPACE_NAME = 'SYSTEM';
3.创建表空间
create tablespace sdt datafile '/home/oracle/app/oracle/oradata/orcl/sdt01.dbf' size 30g;
创建用户并指定表空间
create user sdt identified by 123456 default tablespace sdt;
4.扩充表空间
- 给表空间增加数据文件(数据文件路径=前缀/新数据文件名称)
alter tablespace 表空间名 add datafile '数据文件路径' size 32768M;
eg:
alter tablespace sdt add datafile '/home/oracle/app/oracle/oradata/orcl/sdt02.dbf' SIZE 30g --AUTOEXTEND ON NEXT 1024M;
- 给表空间增加数据文件,并允许数据文件自动增长(数据文件路径=前缀/新数据文件名称)
alter tablespace 表空间名 add datafile '数据文件路径' size 100M autoextend on next 100M maxsize 32768M;
eg:
alter tablespace sdt add datafile '/home/oracle/app/oracle/oradata/orcl/sdt02.dbf' SIZE 30g --AUTOEXTEND ON NEXT 1024M;
- 手工改变已存在数据文件大小
alter database datafile '已存在数据文件路径及名称' resize 32768M
- 使已存在数据文件自动增长
alter database datafile '已存在数据文件路径及名称' autoextend on next 100M maxsize 32768M;