测试:

建表空间

CREATE TABLESPACE TESTTBS DATAFILE '/oradata01/dfhdb/testtbs01.dbf' SIZE 2G;

在表空间上建表

CREATE TABLE TESTTAB TABLESPACE TESTTBS AS SELECT * FROM DBA_OBJECTS;

查找数据文件的编号

SELECT FILE_ID FROM DBA_DATA_FILES WHERE FILE_NAME='/oradata01/dfhdb/testtbs01.dbf';

查找数据文件上面的数据库对象

/* Formatted on 2020/5/19 下午 02:48:46 (QP5 v5.163.1008.3004) */
SELECT E.SEGMENT_TYPE AS SEGMENT_TYPE,
E.OWNER || '.' || E.SEGMENT_NAME AS SEGMENT_NAME,
F.FILE_NAME AS FILE_NAME,
SUM (E.BYTES) / 1024 / 1024/1024 AS SEGMENT_SIZE_GB
FROM DBA_EXTENTS E INNER JOIN DBA_DATA_FILES F ON E.FILE_ID = F.FILE_ID
WHERE F.FILE_ID = 7
GROUP BY E.SEGMENT_TYPE,
E.OWNER,
E.SEGMENT_NAME,
F.FILE_NAME
ORDER BY 4 DESC;

向表中插入数据,查看数据文件的变化

/* Formatted on 2020/5/19 下午 04:31:24 (QP5 v5.163.1008.3004) */
DECLARE
BEGIN
FOR I IN 1 .. 6
LOOP
INSERT INTO TESTTAB
SELECT * FROM TESTTAB; COMMIT;
END LOOP;
END;

查看数据文件的变化

/* Formatted on 2020/5/19 下午 04:14:28 (QP5 v5.163.1008.3004) */
SELECT E.SEGMENT_TYPE AS SEGMENT_TYPE,
E.OWNER || '.' || E.SEGMENT_NAME AS SEGMENT_NAME,
F.FILE_NAME AS FILE_NAME,
SUM (E.BYTES) / 1024 / 1024 / 1024 AS SEGMENT_SIZE_GB
FROM DBA_EXTENTS E INNER JOIN DBA_DATA_FILES F ON E.FILE_ID = F.FILE_ID
WHERE F.FILE_ID = 7
GROUP BY E.SEGMENT_TYPE,
E.OWNER,
E.SEGMENT_NAME,
F.FILE_NAME
ORDER BY 4 DESC;

从这里可以看出,此时如果要resize数据文件,最小应该是0.609375G,因为这以下已经被使用

对表收集统计信息

execute dbms_stats.gather_table_stats(ownname => 'SYS',tabname => 'TESTTAB' ,estimate_percent => DBMS_STATS.AUTO_SAMPLE_SIZE,method_opt => 'for all  columns size auto' ,cascade => true ,degree=>6);

查看表占用了多少个数据块

SELECT TABLE_NAME,
NUM_ROWS,
BLOCKS,
empty_blocks,
LAST_ANALYZED
FROM dba_tables where owner='SYS' and table_name='TESTTAB';

查看表使用的实际块数

SELECT COUNT(DISTINCT DBMS_ROWID.ROWID_BLOCK_NUMBER(ROWID)) USED_BLOCK FROM  SYS.TESTTAB;

通过对比,实际使用的块数和统计信息的差不多,没有多少空块

删除一部分数据,再次查看

DELETE FROM TESTTAB WHERE ROWNUM < 4000000;

再次收集统计信息

查看表实际使用的块数

也就是说总共79457个数据块中只使用了21167,表中存在着大量的空块,同时,也因为这些空块的存在,导致数据文件无法RESIZE。而且,这些空块在全表扫描的时候也会被扫到,影响数据库的性能

消除空块,即降低高水位线

ALTER TABLE SYS.TESTTAB ENABLE ROW MOVEMENT;
ALTER TABLE SYS.TESTTAB SHRINK SPACE;
/*也可以使用MOVE或导入导出,MOVE会导致索引失效,但是比SHRINK快*/

此时再次收集统计信息

可以看到,表占用的数据块数已经降下来了

再次查看数据文件的变化

此时,我们就可以RESIZE数据文件了

通过上述实验,我们可以得出结论,只要我们将数据文件上面的数据库对象的高水位降低(表通过move等,索引通过重建),即可将数据文件的实际使用量缩小,即可释放到OS

找到要操作的数据文件

找到空间不足的目录---》找到目录里面的数据文件---》找到这些数据文件含有的数据库对象个数---》找到数据文件中数据库对象最少的或者只有索引的数据文件(这个就是我们要操作的数据文件)

/* Formatted on 2020/5/19 下午 05:39:26 (QP5 v5.163.1008.3004) */
CREATE TABLE MONKEY.MONKEY_TABLESPACE_RESIZE
(
FILE_ID VARCHAR2 (100 BYTE),
TABLE_COUNT NUMBER,
INDEX_COUNT NUMBER,
TABLE_PAT_COUNT NUMBER,
INDEX_PAT_COUNT NUMBER
); /* Formatted on 2020/5/19 下午 06:00:26 (QP5 v5.163.1008.3004) */
DECLARE
CURSOR FIDS
IS
SELECT FILE_ID
FROM DBA_DATA_FILES
WHERE FILE_NAME LIKE '/ora21data04%'; TABLE_COUNT NUMBER;
TABLE_PAT_COUNT NUMBER;
INDEX_COUNT NUMBER;
INDEX_PAT_COUNT NUMBER;
BEGIN
FOR FID IN FIDS
LOOP
WITH RES
AS ( SELECT E.SEGMENT_TYPE AS SEGMENT_TYPE,
E.OWNER || '.' || E.SEGMENT_NAME AS SEGMENT_NAME,
F.FILE_ID AS FILE_ID
FROM DBA_EXTENTS E
INNER JOIN
DBA_DATA_FILES F
ON E.FILE_ID = F.FILE_ID
WHERE F.FILE_ID = FID.FILE_ID
GROUP BY E.SEGMENT_TYPE,
E.OWNER,
E.SEGMENT_NAME,
F.FILE_ID)
SELECT COUNT (*)
INTO TABLE_COUNT
FROM RES
WHERE SEGMENT_TYPE = 'TABLE'; WITH RES
AS ( SELECT E.SEGMENT_TYPE AS SEGMENT_TYPE,
E.OWNER || '.' || E.SEGMENT_NAME AS SEGMENT_NAME,
F.FILE_ID AS FILE_ID
FROM DBA_EXTENTS E
INNER JOIN
DBA_DATA_FILES F
ON E.FILE_ID = F.FILE_ID
WHERE F.FILE_ID = FID.FILE_ID
GROUP BY E.SEGMENT_TYPE,
E.OWNER,
E.SEGMENT_NAME,
F.FILE_ID)
SELECT COUNT (*)
INTO TABLE_PAT_COUNT
FROM RES
WHERE SEGMENT_TYPE = 'TABLE PARTITION'; WITH RES
AS ( SELECT E.SEGMENT_TYPE AS SEGMENT_TYPE,
E.OWNER || '.' || E.SEGMENT_NAME AS SEGMENT_NAME,
F.FILE_ID AS FILE_ID
FROM DBA_EXTENTS E
INNER JOIN
DBA_DATA_FILES F
ON E.FILE_ID = F.FILE_ID
WHERE F.FILE_ID = FID.FILE_ID
GROUP BY E.SEGMENT_TYPE,
E.OWNER,
E.SEGMENT_NAME,
F.FILE_ID)
SELECT COUNT (*)
INTO INDEX_COUNT
FROM RES
WHERE SEGMENT_TYPE = 'INDEX'; WITH RES
AS ( SELECT E.SEGMENT_TYPE AS SEGMENT_TYPE,
E.OWNER || '.' || E.SEGMENT_NAME AS SEGMENT_NAME,
F.FILE_ID AS FILE_ID
FROM DBA_EXTENTS E
INNER JOIN
DBA_DATA_FILES F
ON E.FILE_ID = F.FILE_ID
WHERE F.FILE_ID = FID.FILE_ID
GROUP BY E.SEGMENT_TYPE,
E.OWNER,
E.SEGMENT_NAME,
F.FILE_ID)
SELECT COUNT (*)
INTO INDEX_PAT_COUNT
FROM RES
WHERE SEGMENT_TYPE = 'INDEX PARTITION'; INSERT INTO MONKEY.MONKEY_TABLESPACE_RESIZE
VALUES (FID.FILE_ID,
TABLE_COUNT,
INDEX_COUNT,
TABLE_PAT_COUNT,
INDEX_PAT_COUNT); COMMIT;
END LOOP;
END;

通过上面的SQL可以查到此目录下的数据文件上的数据库对象个数,进而判断可以RESIZE的数据文件和可操作的数据库对象

89号数据文件上面只有6个普通索引和16个分区索引,没有表,因此可以通过重建这些索引达到RESIZE数据文件的目的

查看89号文件上面的对象.

/* Formatted on 2020/5/19 上午 11:35:38 (QP5 v5.163.1008.3004) */
SELECT E.SEGMENT_TYPE AS SEGMENT_TYPE,
E.OWNER || '.' || E.SEGMENT_NAME AS SEGMENT_NAME,
F.FILE_NAME AS FILE_NAME,
SUM (E.BYTES) / 1024 / 1024 AS SEGMENT_SIZE
FROM DBA_EXTENTS E INNER JOIN DBA_DATA_FILES F ON E.FILE_ID = F.FILE_ID
WHERE F.FILE_ID = 89
GROUP BY E.SEGMENT_TYPE,
E.OWNER,
E.SEGMENT_NAME,
F.FILE_NAME
ORDER BY 4 DESC;

重建或move上面的索引,之后RESIZE数据文件即可。

move索引请参考:https://www.cnblogs.com/monkey6/p/11221643.html

oracle释放空间到OS的更多相关文章

  1. 如何让Oracle释放undo表空间

    如何让Oracle释放undo表空间   最佳答案   在日常的数据库维护和数据库编程中经常会遇到犹豫对大数据量做DML操作后是得ORACLE的undo表空间扩展到十几个G或者几十个G 但是这些表空间 ...

  2. 7个高级技巧帮助你释放大量Mac OS X硬盘空间

    7个高级技巧帮助你释放大量Mac OS X硬盘空间 https://blog.csdn.net/hu434587115/article/details/72874811/

  3. linux删除文件后没有释放空间

    转载 http://blog.csdn.net/wyzxg/article/details/4971843 今天发现一台服务器的home空间满了,于是要清空无用的文件,当我删除文件后,发现可用空间没有 ...

  4. 【转】Oracle 表空间与数据文件

    --============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或 ...

  5. Oracle 表空间与数据文件

    -============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或多 ...

  6. ORACLE临时表空间

    ORACLE临时表空间总结 2014-10-05 11:35 by 潇湘隐者, 临时表空间概念 临 时表空间用来管理数据库排序操作以及用于存储临时表.中间排序结果等临时对象,当ORACLE里需要用到S ...

  7. oracle表空间不足相关问题解决办法

    欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...

  8. Oracle表空间管理

    oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE;              //修改表空间数据文件类型 2.ALT ...

  9. ORACLE 临时表空间清理

    Oracle临时表空间主要用来做查询和存放一些缓冲区数据.临时表空间消耗的主要原因是需要对查询的中间结果进行排序.临时表空间的主要作用: 索引create或rebuildOrder by 或 grou ...

随机推荐

  1. webpack配置css-loader

    执行 npm init 命令 生成 package.json 文件 在 webstorm 项目中局部安装 webpack(比如安装3.6.0版本) npm install webpack@3.6.0 ...

  2. 第七章 Rocketmq--消息驱动

    今天咱们接着 上一篇第六章 Sleuth–链路追踪 继续写 SpringCloud Alibaba全家桶 , 第七章 Rocketmq--消息驱动,废话不多说,开始了 7.1 MQ简介 7.1.1 什 ...

  3. Centos7__Scrapy + Scrapy_redis 用Docker 实现分布式爬虫

    原理:其实就是用到redis的优点及特性,好处自己查--- 1,scrapy 分布式爬虫配置: settings.py BOT_NAME = 'first' SPIDER_MODULES = ['fi ...

  4. 为什么Python多线程无法利用多核

    1.全局解释锁 如题: Python的多线程为什么不能利用多核处理器? 全局解释器锁(Global Interpreter Lock)是计算机程序设计语言解释器用于同步线程的一种机制,它使得任何时刻仅 ...

  5. [UWP] - 修改应用程序在任务栏上的显示Logo

    用VS2015在windows 10上开发一个UWP的应用,由于windows 10对store应用进行了窗口化,因此可以看到在任务栏上看到应用程序的图标,但是看起来会感觉应用Logo会被嵌在另一个容 ...

  6. Spring-步入Spring旅途

    一.Spring前言 讲Spring之前先写段代码,体会一下Java创建对象的方式,这块你理解了对后面有好处! 1.原始时代-new对象 直接new创建对象,代码如下: //User.java pac ...

  7. ElasticSearch设置用户名密码访问

    版本号:7.3.1 1.需要在配置文件中开启x-pack验证, 修改config目录下面的elasticsearch.yml文件,在里面添加如下内容,并重启. xpack.security.enabl ...

  8. Hadoop支持的压缩格式对比和应用场景以及Hadoop native库

    对于文件的存储.传输.磁盘IO读取等操作在使用Hadoop生态圈的存储系统时是非常常见的,而文件的大小等直接影响了这些操作的速度以及对磁盘空间的消耗. 此时,一种常用的方式就是对文件进行压缩.但文件被 ...

  9. Thread通信与唤醒笔记1

    synchronized if判断标记,只有一次,会导致不该信息的线程运行了,出现了数据错误的情况 while判断标记,解决了线程获取执行权之后,是否要运行! notify 只能唤醒一个任意线程,如果 ...

  10. Thymeleaf语法总结 | 笔记分享

    Thymeleaf语法总结 一.Thymeleaf介绍 Thymeleaf是Spring boot推荐使用的模版引擎,直接以html显示,前后端可以很好的分离.   二.Thymeleaf语法(Thy ...