您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息

Truncate数据表背后的几个参数

2024/4/20 4:00:28发布6次查看
truncate语句是oracle sql体系中非常有特色的一个。truncate直接的效果是进行数据表数据的清理,深层次是一种典型的ddl语句。
truncate语句是oracle sql体系中非常有特色的一个。truncate直接的效果是进行数据表数据的清理,深层次是一种典型的ddl语句。
oracle中,delete语句是一种标注动作。在执行过程中,数据库会访问每个符合删除条件的数据行进行标注动作,标记为“已删除”。删除的数据范围越大、执行路径越长,执行sql语句时间也就越长。所以说,delete操作是一个和数据规模成正比的执行过程。
而truncate操作最多接触的知识点是ddl本质。truncate操作下,oracle并不关注每个数据行和数据范围,而是集中修改段头结构、更新核心数据字典上。对于特别巨大的数据表,truncate操作速度要显著快于delete操作。
在11.2.0.x系列版本中,,我们还有一些参数可以用来控制truncate数据表的行为。具体包括:drop storage、drop all storage和reuse storage,每个选项对应truncate数据表的不同行为。本文集中介绍参数的几个选项。
1、环境介绍
笔者使用oracle 11gr2进行测试,版本是11.2.0.4。
sql> select * from v$version;
banner
--------------------------------------------------------------------------------
oracle database 11g enterprise edition release 11.2.0.4.0 - 64bit production
pl/sql release 11.2.0.4.0 - production
core  11.2.0.4.0    production
tns for 64-bit windows: version 11.2.0.4.0 - production
nlsrtl version 11.2.0.4.0 – production
创建专门的非sys用户,注意:这个细节很重要。
sql> create user test identified by test;
user created
sql> grant connect, resource to test;
grant succeeded
sql> grant select_catalog_role to test;
grant succeeded
sql> grant select any dictionary to test;
grant succeeded
登录实验环境,创建数据表。
sql> conn test/test@sicsdb
connected to oracle database 11g enterprise edition release 11.2.0.4.0 
connected as test
sql> show user
user is test
sql> create table t as select * from dba_objects;
table created
sql> create index idx_t_id on t(object_id);
index created
sql> exec dbms_stats.gather_table_stats(user,'t',cascade => true);
pl/sql procedure successfully completed
对应数据段和索引段结构如下:
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='t' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28808      65536          8
        1          4      28816      65536          8
        2          4      28824      65536          8
(篇幅原因,有省略……)
        26          4      30336    1048576        128
27 rows selected
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='idx_t_id' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28936      65536          8
        1          4      28944      65536          8
(篇幅原因,有省略……)
        15          4      30464      65536          8
        16          4      30592    1048576        128
17 rows selected
2、truncate drop storage行为
truncate数据表默认行为包括了drop storage参数。使用drop storage之后,数据表中所有数据都被清空,数据表和索引段只保留一个分区结构。
sql> truncate table t drop storage;
table truncated
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='t' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28808      65536          8
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='idx_t_id' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28936      65536          8
注意:虽然两个段头分区extent的大小和起始段都没有发生变化,依然保持了28808和28936。但是数据字典结构中,认为是一个新的段结构。
sql> select object_name, object_id, data_object_id from dba_objects where owner='test' and object_name in ('t','idx_t_id');
object_name      object_id data_object_id
--------------- ---------- --------------
idx_t_id            123667        123668
t                  123666        123669
t和idx_t_id的object_id和data_object_id不一致了。data_object_id是内部段结构的编号信息。一旦进行truncate操作,就会认为是一个新段生成。
默认truncate操作下,oracle会删除所有数据,回收所有段结构后重新分配一个新的extent。内部的段结构上,oracle认为是在原来段头位置上重新分配的新段。
3、truncate reuse storage行为
下面来测试一下reuse storage参数行为。首先需要重建表数据内容和充实段结构。
sql> insert into t select * from dba_objects;
99693 rows inserted
sql> commit;
commit complete
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='t' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28808      65536          8
        1          4      28816      65536          8
(篇幅原因,有省略……)
        26          4      30720    1048576        128
27 rows selected
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='idx_t_id' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28936      65536          8
        1          4      28840      65536          8
(篇幅原因,有省略……)
        17          4      30208    1048576        128
18 rows selected
操作reuse storage。
sql> truncate table t reuse storage;
table truncated
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='t' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28808      65536          8
        1          4      28816      65536          8
(篇幅原因,有省略……)
        26          4      30720    1048576        128
27 rows selected
sql> select extent_id, file_id, block_id, bytes, blocks from dba_extents where segment_name='idx_t_id' and owner='test';
extent_id    file_id  block_id      bytes    blocks
---------- ---------- ---------- ---------- ----------
        0          4      28936      65536          8
        1          4      28840      65536          8
        2          4      28904      65536          8
(篇幅原因,有省略……)
        17          4      30208    1048576        128
18 rows selected
数据的确删除。
sql> select count(*) from t;
count(*)
----------
        0
reuse storage情况下,段结构没有回收,数据却被删除了!从段结构情况看,oracle依然视之为新段,data_object_id发生变化。
sql> select object_name, object_id, data_object_id from dba_objects where owner='test' and object_name in ('t','idx_t_id');
object_name      object_id data_object_id
--------------- ---------- --------------
idx_t_id            123667        123670
t                  123666        123671
更多详情见请继续阅读下一页的精彩内容:
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录