Oracle 删除大量表记录操作分析总结
存放大数据量的表,其表空间占用也比较大,删除数据后并不会自动释放这些记录占用的表空间,所以,即便表里面数据量很少,查询效率依旧很慢,所以,需要释放表空间。
查询数据表占用的表空间大小SELECT sum(bytes)/(1024*1024) FROM user_segments WHERE segment_name= YOUR_TABLE_NAME 注意,表名必须大写
说明:sum(bytes)/(1024*1024) 数据统计单位由Byte转为GB
整理碎片,释放已删除记录占用的表空间ALTER TABLE your_table_name MOVE;
释放了表空间以后表的ROWID会发生变化,基于ROWID的索引会失效,此时就需要重建索引
重建非分区索引ALTER TABLE your_table_index REBUILD [ONLINE] [NOLOGGING];
重建分区索引
针对分区索引-非组合索引
ALTER INDEX your_table_index REBUILD PARTITION your_partition_name [ONLINE] [NOLOGGING];
注意:
设置日志级别为NOLOGGING 意味尽量减少日志,可以加速索引重建 ONLINE,NOLOGGING 两者位置顺序可以对调,不影响 普通情况下建立索引或者REBUILD索引时,oracle会对基表加共享锁,在这期间,无法对表进行DML操作。如果希望避免这种情况,需要加ONLINE选项 对索引进行REBUILD时,如果不加ONLINE选项,则Oracle直接读取原索引的数据,否则直接扫描表中的数据 ,索引在重建时,查询仍然可以使用旧索引。实际上,Oracle在REBUILD索引的过程中,并不会删除旧索引,直到新索引重建成功,这就是相对删除索引然后重建索引的一个好处:不会影响原有的SQL查询。但也正由于此,用REBUILD方式建立索引需要相应表空间的空闲空间是删除重建方式的2倍。 不能直接REBUILD整个分区索引 对于非组合索引,需要REBUILD每个分区(partition) 对于组合索引,需要REBUILD每个子分区(subpartition) 分区、子分区较多的情况下,可以使用下面的SQL可以生成相应的REBUILD语句重建分区索引-非组合索引
SELECT ALTER INDEX || index_owner || . ||index_name || REBUILD PARTITION || partition_name || NOLOGGING;
FROM dba_ind_partitions
WHERE index_owner = INDEX_OWNER_NAME 可选查询条件,注意,如果指定该条件,索引拥有者必须大写
AND index_name = YOUR_INDEX_NAME 注意,索引名称必须大写
重建分区索引-组合索引
SELECT ALTER INDEX || index_owner || . ||index_name || REBUILD SUBPARTITION || subpartition_name || NOLOGGING;
FROM dba_ind_subpartitions
WHERE index_owner = INDEX_OWNER_NAME 可选查询条件,注意,如果指定该条件,索引拥有者必须大写
AND index_name = YOUR_INDEX_NAME 注意,索引名称必须大写
针对非分区索引,如果清理的表比较多,或者不知道被清理的表拥有哪些索引,可以使用以下SQL查询并生成对应的重建索引SQL
SELECT concat(concat( ALTER INDEX , INDEX_NAME), REBUILD; )FROM all_indexes
WHERE owner= INDEX_OWNER_NAME 可选查询条件,注意,如果指定该条件,索引拥有者必须大写
AND table_name IN( TABLE_NAME1 , TABLE_NAME2 , , TABLE_NAMEN ) 注意,表名必须大写
分析表,是为了使基于CBO的执行计划更加准确,在一定程度上能带来一些性能提升
ANALYZE TABLE table_name COMPUTE STATISTICS; 等价于
ANALYZE TABLE table_name COMPUTE STATISTICS FOR TABLE FOR ALL INDEXES FOR ALL COLUMNS;
说明:生成的统计信息的存放位置:
FOR TABLE的统计信息存在于视图:USER_TABLES 、ALL_TABLES、DBA_TABLES FOR ALL INDEXES的统计信息存在于视图: USER_INDEXES 、ALL_INDEXES、DBA_INDEXES FOR ALL COLUMNS的统计信息存在于试图:USER_TAB_COLUMNS、ALL_TAB_COLUMNS、DBA_TAB_COLUMNS到此这篇关于Oracle 删除大量表记录操作分析总结的文章就介绍到这了,更多相关Oracle 删除大量表 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Oracle 删除大量表记录操作分析总结
相关文章
- 分析Oracle索引创建速度慢的原因(oracle创建索引慢)
- Oracle 触发器类型概念解析(oracle触发器类型)
- 备份Oracle定时备份任务:稳妥藏金!(oracle定时)
- 理论探索 Oracle 冰山理论之旅(oracle冰山)
- Oracle获取自增ID的简易操作(oracle获取自增id)
- 如何在Oracle中实现字段相减操作(oracle字段相减)
- Oracle可视化工具:以更佳的界面操作体验(oracle可视化工具)
- 掌握Oracle授权:精通Oracle授权命令操作技巧(oracle授权命令)
- Oracle实现关联一张表的简单操作(oracle 关联一张表)
- 强大的d3图表帮助企业提升运用Oracle数据的分析能力(d3图表 oracle)
- 01735 Oracle数据库护卫者(01735 oracle)
- Oracle中跨年统计周数技术分析(oracle中跨年的周数)
- 使用Oracle互换列值快速操作数据(oracle互换列值)
- Oracle修复安装过程操作指南(oracle修复安装步骤)
- Oracle传统数据仓库实现精准分析的有效枢纽(oracle传统数据仓库)
- Oracle数据库性能优化框架简介(oracle优化框架)
- Oracle中如何删除表中的索引(oracle中删除表索引)
- Oracle数据库中删除表的操作流程(oracle中删除表操作)
- Oracle数据库实现易用性与高效性(oracle 中.)
- Oracle减少两张表的合并操作(oracle两张表减)
- Oracle登录账户密码不变,下载随意(oracle下载登录账户)
- Oracle 导入 CSV 文件的简易操作(oracle上传csv)
- oracle云数据库服务新增情况2020上一季度Oracle云数据库新增情况分析(oracle 上一季度)
- Oracle S分析字符串处理技术(oracle s截取)
- 开放源代码Oracle GoldenGate解决方案(oracle ogg开源)
- Oracle 19c新增强大特性带来无与伦比的性能(oracle 19c特性)