表空间问题----收缩空间方法:表空间中表的查法:扩展表空间
2016-05-07 11:30
423 查看
收缩空间方法:
一.不删除数据,收缩表空间的数据文件大小,释放磁盘空间
查询对应表所在的表空间
select OWNER,SEGMENT_NAME,TABLESPACE_NAME,BYTES/1024/1024 from dba_segments where segment_name=upper
('t_opt_job_process_log');
查看表空间对应的数据文件大小
select FILE_NAME,FILE_ID,TABLESPACE_NAME,BYTES/1024/1024 mb,BLOCKS from dba_data_files where
TABLESPACE_NAME='TFR_DATA';
查看数据文件中数据处在最大位置
select max(block_id) from dba_extents where file_id=9;
计算表空间实际需要多大空间
select 1354880*8/1024 from dual;
设置表空间大小为该值
ALTER DATABASE DATAFILE '/u01/oradata/FOSSDB/datafile/o1_mf_tfr_data_9ymk9p5n_.dbf' RESIZE 10600M;
二.以上方法收缩能力有限的前提下,进行删除数据收缩
删除数据有两种方式:
(1)删除全表数据,且立即释放空间
truncate table tfr.t_opt_job_process_log;
(2)删除部分数据,收缩表空间
delete from tfr.t_opt_job_process_log where ...;
1.把表移动至一个空间够的表空间里,会立即释放删除掉的数据占用空间
alter table tfr.t_opt_job_process_log move tablespace PKP_DATA;
再将表移动回来即可(不移回来也行)
alter table tfr.t_opt_job_process_log move tablespace TFR_DATA;
2.或者使用以下命令手工释放空间
alter table tfr.t_opt_job_process_log enable row movement;
alter table tfr.t_opt_job_process_log shrink space;
查看表空间中表的大小
select segment_name,
tablespace_name,
bytes B,
bytes / 1024 KB,
bytes / 1024 / 1024 MB from dba_segments where segment_type = 'TABLE'
and tablespace_name = 'USERS' order by bytes desc;
查看表空间中有哪些表
Select Table_Name, Tablespace_Name
From Dba_Tables
Where Tablespace_Name = 'TFR_DATA';
Select *
From Dba_Tables
Where Tablespace_Name = 'USERS';这样可以看到表是哪个用户的
查看表空间-可以查看到表空间文件
select b.file_name 物理文件名,
b.tablespace_name 表空间,
b.bytes/1024/1024 大小M,
(b.bytes-sum(nvl(a.bytes,0)))/1024/1024 已使用M,
substr((b.bytes-sum(nvl(a.bytes,0)))/(b.bytes)*100,1,5) 利用率
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_name,b.bytes
order by b.tablespace_name
http://blog.csdn.net/starnight_cbj/article/details/6792364-表空间更多内容 查看表空间-查看每个表空间总大小和使用情况SELECT a.tablespace_name , total / (1024 * 1024*1024 ) sizeG,
free / (1024 * 1024 *1024) freeG, (total - free) / (1024 * 1024*1024 ) UsedG,
round((total - free) / total, 4) * 100 Perc
FROM (SELECT tablespace_name, SUM(bytes) free FROM dba_free_space GROUP BY tablespace_name) a,
(SELECT tablespace_name, SUM(bytes) total FROM dba_data_files GROUP BY tablespace_name) b
WHERE a.tablespace_name = b.tablespace_name
order by a.tablespace_name;
--删除空的表空间,但是不包含物理文件
drop tablespace tablespace_name;
--删除非空表空间,但是不包含物理文件
drop tablespace tablespace_name including contents;
--删除空表空间,包含物理文件
drop tablespace tablespace_name including datafiles;
--删除非空表空间,包含物理文件
drop tablespace tablespace_name including contents and datafiles;
--如果其他表空间中的表有外键等约束关联到了本表空间中的表的字段,就要加上CASCADE CONSTRAINTS
drop tablespace tablespace_name including contents and datafiles CASCADE CONSTRAINTS;
SELECT a.tablespace_name "表空间名",
total "表空间大小",
free "表空间剩余大小",
(total - free) "表空间使用大小",
total / (1024 * 1024 * 1024) "表空间大小(G)",
free / (1024 * 1024 * 1024) "表空间剩余大小(G)",
(total - free) / (1024 * 1024 * 1024) "表空间使用大小(G)",
round((total - free) / total, 4) * 100 "使用率 %"
FROM (SELECT tablespace_name, SUM(bytes) free
FROM dba_free_space
GROUP BY tablespace_name) a,
(SELECT tablespace_name, SUM(bytes) total
FROM dba_data_files
GROUP BY tablespace_name) b
查看SYSTEM这个表空间是否自动增长。。
SELECT file_id, file_name, tablespace_name, autoextensible, increment_by
FROM dba_data_files
WHERE tablespace_name = 'SYSTEM'
order by file_id desc;
扩展表空间新增加文件alter tablespace SYSTEM add datafile '/usr/kingdee/oradata/smsdb/users03.dbf' size 500Mautoextend on; 扩展已经有的文件alter database datafile '/usr/kingdee/oradata/smsdb/users03.dbf' resize 100000M
设置表空间自动增长alter database datafile '/u01/oradata/FOSSDB/datafile/o2_mf_bse_data_blh6ov4m_.dbf' autoextend on;
查看某个表的大小
select G.owner,g.table_name,sum (G.sizeG) totalG
from (
select d.owner,d.segment_name,d.segment_type,d.partition_name,f.table_name,d.tablespace_name,
trunc(d.bytes/1024 /1024/ 1024,2 ) sizeG
from dba_segments d ,
(
select a.owner,a.table_name segment_name,a.table_name from dba_tables a
where a.table_name='T_SRV_WAYBILL_TEST'
union
select b.owner,b.index_name segment_name,b.table_name from dba_indexes b
where b.table_name='T_SRV_WAYBILL_TEST'
union
select c.owner, c.segment_name,c.table_name from dba_lobs c
where c.table_name='T_SRV_WAYBILL_TEST'
)f
where d.owner=f.owner and d.segment_name =f.segment_name
ORDER BY d.bytes DESC
)G
group by G.owner,G.table_name;
标黑的地方换成你要查询的表的名字。
一.不删除数据,收缩表空间的数据文件大小,释放磁盘空间
查询对应表所在的表空间
select OWNER,SEGMENT_NAME,TABLESPACE_NAME,BYTES/1024/1024 from dba_segments where segment_name=upper
('t_opt_job_process_log');
查看表空间对应的数据文件大小
select FILE_NAME,FILE_ID,TABLESPACE_NAME,BYTES/1024/1024 mb,BLOCKS from dba_data_files where
TABLESPACE_NAME='TFR_DATA';
查看数据文件中数据处在最大位置
select max(block_id) from dba_extents where file_id=9;
计算表空间实际需要多大空间
select 1354880*8/1024 from dual;
设置表空间大小为该值
ALTER DATABASE DATAFILE '/u01/oradata/FOSSDB/datafile/o1_mf_tfr_data_9ymk9p5n_.dbf' RESIZE 10600M;
二.以上方法收缩能力有限的前提下,进行删除数据收缩
删除数据有两种方式:
(1)删除全表数据,且立即释放空间
truncate table tfr.t_opt_job_process_log;
(2)删除部分数据,收缩表空间
delete from tfr.t_opt_job_process_log where ...;
1.把表移动至一个空间够的表空间里,会立即释放删除掉的数据占用空间
alter table tfr.t_opt_job_process_log move tablespace PKP_DATA;
再将表移动回来即可(不移回来也行)
alter table tfr.t_opt_job_process_log move tablespace TFR_DATA;
2.或者使用以下命令手工释放空间
alter table tfr.t_opt_job_process_log enable row movement;
alter table tfr.t_opt_job_process_log shrink space;
查看表空间中表的大小
select segment_name,
tablespace_name,
bytes B,
bytes / 1024 KB,
bytes / 1024 / 1024 MB from dba_segments where segment_type = 'TABLE'
and tablespace_name = 'USERS' order by bytes desc;
查看表空间中有哪些表
Select Table_Name, Tablespace_Name
From Dba_Tables
Where Tablespace_Name = 'TFR_DATA';
Select *
From Dba_Tables
Where Tablespace_Name = 'USERS';这样可以看到表是哪个用户的
查看表空间-可以查看到表空间文件
select b.file_name 物理文件名,
b.tablespace_name 表空间,
b.bytes/1024/1024 大小M,
(b.bytes-sum(nvl(a.bytes,0)))/1024/1024 已使用M,
substr((b.bytes-sum(nvl(a.bytes,0)))/(b.bytes)*100,1,5) 利用率
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_name,b.bytes
order by b.tablespace_name
http://blog.csdn.net/starnight_cbj/article/details/6792364-表空间更多内容 查看表空间-查看每个表空间总大小和使用情况SELECT a.tablespace_name , total / (1024 * 1024*1024 ) sizeG,
free / (1024 * 1024 *1024) freeG, (total - free) / (1024 * 1024*1024 ) UsedG,
round((total - free) / total, 4) * 100 Perc
FROM (SELECT tablespace_name, SUM(bytes) free FROM dba_free_space GROUP BY tablespace_name) a,
(SELECT tablespace_name, SUM(bytes) total FROM dba_data_files GROUP BY tablespace_name) b
WHERE a.tablespace_name = b.tablespace_name
order by a.tablespace_name;
--删除空的表空间,但是不包含物理文件
drop tablespace tablespace_name;
--删除非空表空间,但是不包含物理文件
drop tablespace tablespace_name including contents;
--删除空表空间,包含物理文件
drop tablespace tablespace_name including datafiles;
--删除非空表空间,包含物理文件
drop tablespace tablespace_name including contents and datafiles;
--如果其他表空间中的表有外键等约束关联到了本表空间中的表的字段,就要加上CASCADE CONSTRAINTS
drop tablespace tablespace_name including contents and datafiles CASCADE CONSTRAINTS;
SELECT a.tablespace_name "表空间名",
total "表空间大小",
free "表空间剩余大小",
(total - free) "表空间使用大小",
total / (1024 * 1024 * 1024) "表空间大小(G)",
free / (1024 * 1024 * 1024) "表空间剩余大小(G)",
(total - free) / (1024 * 1024 * 1024) "表空间使用大小(G)",
round((total - free) / total, 4) * 100 "使用率 %"
FROM (SELECT tablespace_name, SUM(bytes) free
FROM dba_free_space
GROUP BY tablespace_name) a,
(SELECT tablespace_name, SUM(bytes) total
FROM dba_data_files
GROUP BY tablespace_name) b
查看SYSTEM这个表空间是否自动增长。。
SELECT file_id, file_name, tablespace_name, autoextensible, increment_by
FROM dba_data_files
WHERE tablespace_name = 'SYSTEM'
order by file_id desc;
扩展表空间新增加文件alter tablespace SYSTEM add datafile '/usr/kingdee/oradata/smsdb/users03.dbf' size 500Mautoextend on; 扩展已经有的文件alter database datafile '/usr/kingdee/oradata/smsdb/users03.dbf' resize 100000M
设置表空间自动增长alter database datafile '/u01/oradata/FOSSDB/datafile/o2_mf_bse_data_blh6ov4m_.dbf' autoextend on;
查看某个表的大小
select G.owner,g.table_name,sum (G.sizeG) totalG
from (
select d.owner,d.segment_name,d.segment_type,d.partition_name,f.table_name,d.tablespace_name,
trunc(d.bytes/1024 /1024/ 1024,2 ) sizeG
from dba_segments d ,
(
select a.owner,a.table_name segment_name,a.table_name from dba_tables a
where a.table_name='T_SRV_WAYBILL_TEST'
union
select b.owner,b.index_name segment_name,b.table_name from dba_indexes b
where b.table_name='T_SRV_WAYBILL_TEST'
union
select c.owner, c.segment_name,c.table_name from dba_lobs c
where c.table_name='T_SRV_WAYBILL_TEST'
)f
where d.owner=f.owner and d.segment_name =f.segment_name
ORDER BY d.bytes DESC
)G
group by G.owner,G.table_name;
标黑的地方换成你要查询的表的名字。
相关文章推荐
- 表空间操作
- oracle中创建数据库和表空间的几点总结
- Oracle表空间查看sql使用情况
- mysql 表空间及索引的查看方法
- Shell脚本实现硬盘空间和表空间的使用情况统计并邮件通知
- Oracle数据库中表空间的基本管理操作小结
- Oracle中如何把表和索引放在不同的表空间里
- Oracle表空间数据文件移动的方法
- InnoDB独立表空间
- Oracle表空间查看sql使用情况
- Oracle - 数据库的实例、表空间、用户、表之间关系
- 表空间迁移(一)
- 表空间迁移(三)
- ORACLE 管理 日志与空间
- Oracle - 数据库的实例、表空间、用户、表之间关系
- 创建表空间及用户
- oracle 创建表空间和用户名
- Oracle表空间,用户,用户授权
- Oracle创建表空间和授权
- 数据库表空间