表空间问题----收缩空间方法:表空间中表的查法:扩展表空间
admin
2023-06-10 14:43:39
0

收缩空间方法:

一.不删除数据,收缩表空间的数据文件大小,释放磁盘空间


查询对应表所在的表空间

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 500M

autoextend on; 

扩展已经有的文件

alter database datafile '/usr/kingdee/oradata/smsdb/users03.dbf' resize 100000M


设置表空间自动增长

alter database datafile '/u01/oradata/FOSSDB/datafile/o2_mf_bse_data_blh7ov4m_.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;


标黑的地方换成你要查询的表的名字。

相关内容

热门资讯

直击重庆永川特大暴雨:一院子5... 5月24日凌晨,重庆市永川区特大暴雨导致3人死亡17人失联,目前搜救工作又有新进展。5月25日上午1...
网红打卡点,女厕所藏针孔摄像头 近日,有女性博主发布声明,称在成都市金牛区某饮品店拍摄时,被他人在店铺厕所安装的针孔摄像头偷拍,相关...
解决问题是AI产品最朴素的竞争... 来源:科技日报 我们在日常生活中可能会遇到这样的情形,AI手机、AI眼镜、AI音箱持续出新,号称具备...
女子产后康复时突发呼吸心跳骤停... 时年39岁的车女士,生下小儿子不久成了植物人。2022年7月24日,她在洛阳市妇幼保健院做产后康复期...
被以扣押澳活动人士回国,称遭数... 据凤凰卫视报道,参与“全球坚韧船队”援助加沙行动期间,被以色列扣押的11名澳大利亚活动人士近日陆续返...
智汇青联 | 一块提花布,看传... 智汇 青联 绍兴市青年联合会 青春逢盛世,学习正当时。为进一步汇聚青联智慧,赋能青年成长成才,绍兴市...
大庆油田成功构建开发区级三维精... 中新网大庆5月25日电 (王立峰)25日,记者从大庆油田了解到,为进一步盘活杏南开发区区域内难动用储...
原创 硅... 一、硅酸盐的奥秘 硅酸盐是由硅、氧和金属元素组成的化合物大家族,构成了地球岩石圈的主要成分,约占地壳...
原相3955XM+TL3228... 一、前言:小米电竞外设重新起步 小米一直被网友戏称为杂货铺,它提供了五花八门的各种产品,各个领域都有...
修理厨房灯具多少钱 修理厨房灯具的费用会因多种因素而异,以下是一些可能影响价格的因素:1. 灯具类型:不同类型的灯具,如...