在oracle中,对于数据库中的大数据量在delete时,速度那是相当的慢。其实可以有另外的删除数据的方法,就是可以使用truncate来删除表中的数据。但这种方法在删除时,虽然速度比delete快很多。但由于是不可回滚的,因此在truncate后,数据是无法恢复的。这一点很重要,一定要记牢。
下面,我们来了解一下为什么truncate会比delete快很多。
它们都是删除表中的数据,而不能删除表结构,delete 可以删除整个表的数据也可以删除表中某一条或N条满足条件的数据,而truncate只能删除整个表的数据,一般我们把delete 操作收作删除表,而truncate操作叫作截断表。
truncate操作与delete操作对比
操作 回滚 高水线 空间 效率
Truncate 不能 下降 回收 快
delete 可以 不变 不回收 慢
下面分别用实例查看它们的不同
1、回滚
首先要明白两点
1.在oracle 中数据删除后还能回滚是因为它把原始数据放到了undo表空间,
2.DML语句使用undo表空间,DDL语句不使用undo,而delete是DML语句,truncate是DDL语句,别外DDL语句是隐式提交.
所以truncate操用不能回滚,而delete操作可以.
2、高水线
所有的Oracle表都有一个容纳数据的上限(很象一个水库历史最高的水位),我们把这个上限称为“high water mark”或HWM。这个HWM是一个标记(专门有一个数据块用来记录高水标记等),用来说明已经有多少数据块分配给这个表. HWM通常增长的幅度为一次5个数据块.
delete语句不影响表所占用的数据块, 高水线(high watermark)保持原位置不动
truncate 语句缺省情况下空间释放,除非使用reuse storage; truncate会将高水线复位
高水线的作用: HWM对数据库的操作有如下影响:
a) 全表扫描通常要读出直到HWM标记的所有的属于该表数据库块,即使该表中没有任何数据。
b) 即使HWM以下有空闲的数据库块,键入在插入数据时使用了append关键字,则在插入时使用HWM以上的数据块,此时HWM会自动增大。
因此高水线是oracle优化时一个重要的参数
3、空间
既然高水线用来说明已经有多少数据块分配给这个表,那么高水线也可理解为表的空间占用。
即使delete将表中的数据全部删除,HWM还是为原值,所以还有那么多的空间分配给这个表,即它的空间还没有回收,
而truncate表后高水线变为0,那现在它就表示没有分配空间,即它的空间被回收了。
4、效率
在相同的数据量删除的情况下,truncate会比delete快几十倍。这个在真实的环境中测试过。
另外,在truncate时,当表中有主外键约束时,会抛出如下的错误:
truncate table table_name * ERROR 位于第 1 行: ORA-02266: 表中的唯一/主键被启用的外部关键字引用。
处理此问题的总体思路是:先将表中的主外键设置为不可用,设置成功后,则就可以truncate了。truncate后,一定要再次将主外键设置为可用。否则可能引发其他重大问题哦!
具体处理方法如下:
alter table table_name disable primary key cascade; --表已更改。
truncate table table_name; --表已截掉。
alter table table_name enable primary key;-- 表已更改。
分享到:
相关推荐
### Oracle数据库中的海量数据处理 #### 数据仓库系统的特点与Oracle数据仓库简介 数据仓库系统是一种专门设计用于存储、管理和分析企业历史数据的信息管理系统。它的特点包括面向主题、集成性、随时间变化以及非...
通过上述方法,我们可以有效地清除Oracle分区表中的数据。选择合适的方法取决于具体的应用场景以及对性能和安全性的要求。例如,如果只需要临时性地清理数据而无需保留日志,则可以优先考虑使用TRUNCATE命令;如果...
- **数据集成**:将来自不同业务系统的数据集中存储和管理,消除数据孤岛。 - **提高决策效率**:通过数据分析工具提供直观的数据视图,帮助企业领导层快速做出决策。 - **降低成本**:减少数据冗余和重复处理,简化...
- **原理**:当使用`DROP`命令删除表后,Oracle并没有立即清除表占用的空间,而是将其放入了一个特殊的区域——回收站中,直到这些空间被新的数据覆盖。 - **查询回收站**:可以通过查询`USER_TABLES`视图或`USER_...
4. 在 Show Data 界面中,可以使用一些图标,如清除当前对象中的数据、启用约束和触发器等。 5. 点击 Import,选择外部文件的格式,如 txt、xls、mdb,可以加载以前保存的设置,也可以保存现在的设置。 6. 选择待...
在查询方面,`SELECT`语句是基础,用于从表中获取数据。例如,`SELECT * FROM student`获取student表的所有数据。`SELECT name||'(‘||id||’)’ EMPLOYEE FROM employee`则是将name和id组合成一个新的字段。`NVL`...
首先,DBF文件在Oracle数据库中扮演着核心角色,它们存储了数据库的所有表、索引和其他对象的数据。当数据库遇到问题,如硬件故障、逻辑错误或人为失误导致的数据丢失,DBF文件的备份和恢复能力就显得至关重要。 ...
它通过高效的数据组织和处理机制,为企业提供快速的数据访问和分析能力。本篇文章将详细介绍Oracle数据仓库的几个关键知识点,包括分区技术、报表优化技术和并行处理应用。 首先,让我们深入探讨Oracle的分区技术。...
在Oracle数据库恢复过程中,"system01.dbf"文件特别关键,它是系统表空间的数据文件,包含了数据库的元数据,如表定义、索引、用户权限等。"undotbs01.dbf"文件则属于回滚表空间,用于存储事务回滚信息,当事务需要...
Oracle数据库中的事务槽(ITL, Incident Transaction List)是数据块内部管理并发事务的重要机制。在Oracle中,每个数据块可以包含多个事务槽,用于跟踪并发事务对数据块的更改。当事务对数据块进行读写操作时,就会...
`:仅清除表中的数据,保留表结构,不写入重做日志,数据不可恢复。 - **示例**:`DROP TABLE student;` 或 `TRUNCATE TABLE student;` **8. 插入数据** - **语法**:`INSERT INTO 表名 (列1, 列2, ...) VALUES (值...
总的来说,Oracle 10g的回收站功能虽然提供了数据保护,但也可能导致数据库中积累垃圾表。通过`SHOW RECYCLEBIN`和`PURGE`命令,我们可以有效地管理和清理这些表,以保持数据库的高效运行和优化存储资源。在日常...
2. **数据集成**:数据仓库中的数据是从各种不同的操作型系统中抽取、清洗和转换而来的,目的是消除数据不一致性和矛盾,确保数据的一致性和准确性。 3. **稳定性**:数据仓库中的数据是静态的,主要反映历史状态,...
当我们向表中插入新记录时,Oracle会根据索引的定义,将新记录的索引键值插入到正确的索引位置,而不是简单地寻找空闲的数据块。这是因为索引需要保持键值的排序,以便于快速查找。如果新记录的索引键值对应的数据...
在Oracle数据库管理中,清空所有表数据是一个常见的操作,特别是在进行数据清理、测试环境的重置或系统恢复时。以下是一种有效的方法,分为三个主要步骤来实现这一目标: 1. **删除所有外键约束**: 在Oracle...
- **索引组织表(Index-organized Tables)**:一种特殊类型的表,其中的数据行存储在主键索引中,而不是单独的数据块中。 - **索引(Indexes)**:用于加速查询操作的数据库对象。 - **回滚管理(Undo Management)...
Oracle 数据库分区表是关系型数据库中的一种重要技术,旨在解决海量数据处理问题。在当前互聯網技术和电子商业发展的时代,大数据已经成为企业面临的主要挑战之一。如何处理好海量数据,已经成为任何数据管理系统...
### Oracle全面业务数据整合之道——消除企业信息孤岛 #### 企业信息化面临的问题与关注点 随着信息技术的快速发展,企业面临着越来越复杂的信息管理和处理需求。信息孤岛问题成为了企业信息化进程中的一大挑战。...
Oracle ITL(Interested Transaction List)事务槽是数据库管理系统Oracle中用于处理并发事务处理的重要组成部分,主要存在于数据块的内部。ITL的主要职责是记录在数据块中发生的事务,无论是已提交还是未提交的。每...
在Oracle中,`TRUNCATE TABLE`是一种特殊的删除操作,它不记录单个行的删除,而是快速清除表中的所有数据,适用于需要彻底清空表的情况。与`DELETE`不同,`TRUNCATE`不会触发触发器,也不能被回滚,因此在效率上更高...