Oracle 删除大量表记录操作分析总结

作者:授客 时间:2024-01-22 20:36:12 

删除表数据操作

清空所有表记录:

TRUNCATE TABLE your_table_name;

或者批量删除满足条件的表记录:

BEGIN
 LOOP
   DELETE FROM your_table_name WHERE rownum <= 50000;
     EXIT WHEN SQL%ROWCOUNT = 0;
  COMMIT;
END LOOP;
END;

释放表空间

存放大数据量的表,其表空间占用也比较大,删除数据后并不会自动释放这些记录占用的表空间,所以,即便表里面数据量很少,查询效率依旧很慢,所以,需要释放表空间。

-- 查询数据表占用的表空间大小
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 意味尽量减少日志,可以加速索引重建

  • ONLINENOLOGGING 两者位置顺序可以对调,不影响

  • 普通情况下建立索引或者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_TABLESDBA_TABLES

  • FOR ALL INDEXES的统计信息存在于视图: USER_INDEXES 、ALL_INDEXESDBA_INDEXES

  • FOR ALL COLUMNS的统计信息存在于试图:USER_TAB_COLUMNSALL_TAB_COLUMNSDBA_TAB_COLUMNS

来源:https://www.cnblogs.com/shouke/p/16706285.html

标签:Oracle,删除,表
0
投稿

猜你喜欢

  • 修改apache配置文件去除thinkphp url中的index.php

    2024-05-21 10:21:10
  • Python脚本传参数argparse模块的使用

    2023-02-28 23:07:21
  • Python常用字符串替换函数strip、replace及sub用法示例

    2022-04-07 18:21:17
  • Python机器学习入门(五)之Python算法审查

    2021-10-15 09:27:48
  • Python操作MySQL数据库的方法

    2024-01-28 10:49:27
  • python实现超级玛丽游戏

    2023-10-02 20:19:28
  • MySQL 如何修改root用户的密码

    2024-01-23 19:34:31
  • Vue mockjs编写假数据并请求获取实现流程

    2024-04-28 09:27:22
  • jQuery 取得 background-position 的值

    2009-04-05 16:02:00
  • 如何做网页设计的10个小窍门

    2010-04-11 22:30:00
  • Python Serial串口基本操作(收发数据)

    2022-04-17 09:54:07
  • smarty缓存用法分析

    2024-06-07 15:44:41
  • 使用Selenium实现微博爬虫(预登录、展开全文、翻页)

    2022-07-09 11:00:18
  • Python如何获取文件路径/目录

    2021-09-01 09:05:18
  • pytorch: tensor类型的构建与相互转换实例

    2023-06-14 09:22:57
  • python的语句结构你真的了解吗

    2022-08-11 23:05:39
  • 使用 Python 处理3万多条数据只要几秒钟

    2023-08-03 15:21:06
  • SQL server分页的4种方法示例(很全面)

    2024-01-27 15:09:47
  • python2.7安装opencv-python很慢且总是失败问题

    2021-01-10 06:11:15
  • 解决windows下python3使用multiprocessing.Pool出现的问题

    2021-11-03 23:34:37
  • asp之家 网络编程 m.aspxhome.com