insert的时候使用append会不会影响到表的大小

我们在insert表的时候,经常会使用append的方式来提高效率.
append的会将insert的数据直接加到表的最后,而不会在表的空闲块中插入数据.无论是归档模式还是非归档模式,append会减少产生的日志,产生的UNDO也比较少。append属于direct insert,因此会提高insert的效率.

那么insert使用append与不使用append,表的大小会不会不同呢?
我简单做了个试验:

(1)在没有做insert之前的表的
select * from dba_segments where tablespace_name='TS_CHARIS';
HEADER_BLOCK BYTES BLOCKS
45835 1342177280 163840

原表数据占用163840个块

(2)执行insert(不使用append)
SQL> insert into TEST_PARALLEL (select * from tmp_mid_data);

5000000 rows created.

Elapsed: 00:01:35.97
SQL>
SQL> rollback;

Rollback complete.

Elapsed: 00:04:03.95
SQL>

select * from dba_segments where tablespace_name='TS_CHARIS';
HEADER_BLOCK BYTES BLOCKS
45835 1879048192 229376

可以看到没有使用append的方式的BLOCKS为229376

(3)恢复数据到原来的数据
SQL> alter table TEST_PARALLEL move;

Table altered.

Elapsed: 00:04:12.97

select * from dba_segments where tablespace_name='TS_CHARIS';

HEADER_BLOCK BYTES BLOCKS
45891 1342177280 163840

恢复原表占用163840个BLOCKS

(4)执行insert(使用append)
SQL> insert /*+ append */ into TEST_PARALLEL (select * from tmp_mid_data);

5000000 rows created.

Elapsed: 00:01:19.12
SQL> rollback;

Rollback complete.

Elapsed: 00:00:00.05
SQL>


select * from dba_segments where tablespace_name='TS_CHARIS';

HEADER_BLOCK BYTES BLOCKS
45891 1879048192 229376

加append的与不加append的方式,表的占用空间相同.另外通过两次rollback的时间比较,前者花费了4分,后者花费了不到1秒,说明不使用append进行insert的话,会占用undo空间,rollback会进行计算;而使用append则不会占用太大的空间.

(5)继续进行试验(模拟存在碎片的情况)
SQL> alter table TEST_PARALLEL move;

Table altered.

Elapsed: 00:03:30.89
SQL> insert into TEST_PARALLEL (select * from tmp_mid_data);

5000000 rows created.

Elapsed: 00:01:25.86
SQL> rollback;

Rollback complete.

Elapsed: 00:04:09.86

此时的表占用的空间情况:
select * from dba_segments where tablespace_name='TS_CHARIS';
HEADER_BLOCK BYTES BLOCKS
45891 1879048192 229376

SQL> insert into TEST_PARALLEL (select * from tmp_mid_data where rownum <1000001);

1000000 rows created.

Elapsed: 00:01:04.92

此时的表占用的空间情况:
HEADER_BLOCK BYTES BLOCKS
45891 1879048192 229376

可以看到,由于表存在碎片,所以这次insert的之后,表的空间没有再变化(高水位没有变化).新插入的数据都保存在空闲的空间之中.
SQL> rollback;

Rollback complete.

Elapsed: 00:00:02.76
SQL>
SQL>
SQL>
SQL> insert /*+ append */ into TEST_PARALLEL (select * from tmp_mid_data where rownum <1000001);

1000000 rows created.

Elapsed: 00:00:30.11
SQL>
SQL> rollback;

Rollback complete.

Elapsed: 00:00:00.03

再看看表占用的空间,如果使用append的话,insert会直接从表的高水位开始追加数据.
HEADER_BLOCK BYTES BLOCKS
45891 2013265920 245760


通过实验可以说明:
1.使用append可以提高insert的效率;
2.使用append很少使用UNDO空间;
3.使用append不会使用表中存在的碎片空间,会直接从表的高水位开始追加数据.

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/23850820/viewspace-1041319/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/23850820/viewspace-1041319/

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Oracle中的"append nologging"是一种数据插入方式,它可以在插入数据时不写入日志文件,从而提高数据插入的效率。但是,这种方式也带来一定的风险,因为如果系统崩溃或出现故障,这些未记录的数据将无法恢复。因此,在使用"append nologging"时需要谨慎考虑,并根据具体情况进行选择。 ### 回答2: 在Oracle数据库中,"append nologging"是一个用于插入数据的选项。当我们使用这个选项时,告知Oracle不要将数据更改记录的日志信息写入日志文件中。 使用"append nologging"选项有以下几个优点: 1. 提高插入性能:由于不需要将每个插入操作的详细信息写入日志文件,可以大大减少写操作对性能的影响。这对于大批量数据插入操作特别有效,可以显著提高插入速度。 2. 减少日志文件大小:由于没有记录每个插入操作的日志,可以减少日志文件的大小。这对于需要保留日志一段时间的数据库来说,可以显著减少存储空间的使用。 3. 简化恢复过程:由于没有详细的插入操作日志,恢复过程可以更简单。在某些情况下,可以通过简单的回滚操作来还原数据。 然而,使用"append nologging"选项也存在一些风险和限制: 1. 不能进行点恢复:由于没有详细的插入操作日志,当发生故障时无法进行点恢复。如果需要恢复到插入操作之前的状态,只能进行完全恢复。 2. 必须小心使用:"append nologging"选项要谨慎使用,必须仔细评估数据的重要性和对插入操作的恢复需求。如果数据丢失将造成严重问题,应该避免使用此选项。 3. 仅适用于插入操作:"append nologging"选项只适用于插入操作,对其他数据操作(如更新和删除)无效。 总之,"append nologging"选项是Oracle数据库中一个能够提高插入性能和减少存储空间使用的选项,但使用时需要注意数据的重要性和对插入操作的恢复需求。 ### 回答3: 在Oracle数据库中,"append nologging"是一种表级别的选项,用于指定在数据插入操作中不生成任何日志信息。通过使用"append nologging"选项,可以提高数据插入的性能。 当我们执行插入操作时,默认情况下,Oracle将插入的数据写入日志文件中,以确保数据的持久性和安全性。然而,对于一些大规模的数据插入操作,特别是对于临时或者不重要的数据,生成日志文件可能成为性能瓶颈。这时,我们可以选择使用"append nologging"选项,该选项禁止生成日志文件,从而提高插入操作的性能。 使用"append nologging"选项需要谨慎,因为它可能导致数据丢失的风险。由于没有生成日志文件,一旦系统发生故障或者崩溃,这些没有被记录的数据将无法恢复。因此,在使用"append nologging"选项时,需要确保数据的重要性和可恢复性,并做好相应的数据备份和恢复策略。 可以通过以下语法在Oracle中使用"append nologging"选项: ``` INSERT /*+ APPEND NOLOGGING */ INTO table_name (column1, column2, ...) VALUES (value1, value2, ...); ``` 在上述语句中,通过在INSERT语句中添加"/*+ APPEND NOLOGGING */"注释来启用"append nologging"选项。然后,我们可以指定要插入的表名和对应的列和值。 需要注意的是,使用"append nologging"选项并不会对查询和更新操作产生影响。它只适用于插入操作,并且仅在一些特定的情况下才建议使用,例如临时表、快速数据装载等。 总之,"append nologging"是Oracle数据库中的一个选项,用于指定在数据插入操作中不生成任何日志信息,从而提高插入操作的性能。但是,需要谨慎使用,并做好相应的数据备份和恢复策略。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值