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
意味尽量减少日志,可以加速索引重建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
来源:https://www.cnblogs.com/shouke/p/16706285.html


猜你喜欢
- 有过一定的 Python 经验的开发者都知道,当引入第三方包时,我们常常会使用 pip install 命令来下载并导入包。那么,如何写一个
- IE下专属CSS:<![if !IE]><link rel="stylesheet" type=&qu
- 下载golint下载golang 的 lint,下载地址:https://github.com/golang/lintmkdir -p $G
- 看到有人在有汉字的字符串 前加一个 ‘ 或是任意半角符号,让bug将其除掉,不过这样做太麻烦了。最后呢,找来一个模拟fgetcsv功能的函数
- 最近做网站期间遇到个问题,就是用到比较流行的lightbox效果,就是点击链接后会弹出个固定大小窗口,弹出后窗口下面的内容是被遮罩掉的,最近
- 和网友们讨论了数组取交集的方法,下面是两个实现arr1=["1","5","6"
- 1. 函数式编程概述1.1. 什么是函数式编程?函数式编程使用一系列的函数解决问题。函数仅接受输入并产生输出,不包含任何能影响产生输出的内部
- python字符串字符串是 Python 中最常用的数据类型。我们可以使用引号('或")来创建字符串。创建字符串很简单,只
- selenium 介绍selenium 是一个 web 的自动化测试工具,不少学习功能自动化的同学开始首选 selenium ,因为它相比
- 本文以连接错误ECONNREFUSED为例,看看nodejs对错误处理的过程。 假设我们有以下代码1. const net =
- 操作实现函数: 代码如下:Function AddWater(n) Set Photo = 
- 刚刚有人问我二年前写的那个小三角的效果还能作出什么样的效果,我正在看电视,画面上出现了这样一个小灯笼,于是,我就说,可以作个小灯笼玩玩。于是
- 1.在查询分析器理启动或停止SQL Agent服务启动:use mastergoxp_cmdshell 'net start SQL
- PYTHON Pandas批量读取csv文件到DATAFRAME首先使用glob.glob获得文件路径。然后定义一个列表,读取文件后再使用c
- 在指定路径下新建一个文件夹:import osdef newfile(path): path=path.strip() path=path.
- SQLserver 2000中出现“指定的服务并未以已安装的服务存在" 解决方案一、将计算机名改成大写。二、将sql server
- 描述remove() 函数用于移除列表中某个值的第一个匹配项。语法remove()方法语法:list.remove(obj)参数obj --
- 在SQL Server中,提供了通过Exchange或Outlook收发邮件的扩展存储过程。下面简单地介绍一下:一、启动SQL Mail:x
- 现在大部分网站都使用asp+access构建,这样的话通过下载access数据库简单就可以对网站进行破坏! 而很多的网站都不太重
- 2008年,对于JavaScript来说是非常振奋人心的一年,很多高人加入到JavaScript和Web开发的阵营中来,浏览器厂商在技术上互