前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >TRUNCATE TABLE后 SEGMENT_SIZE没有改变

TRUNCATE TABLE后 SEGMENT_SIZE没有改变

作者头像
星哥玩云
发布2022-08-16 14:32:31
4010
发布2022-08-16 14:32:31
举报
文章被收录于专栏:开源部署

测试环境中,历史的交易表可以清空,仅需保留表结构。于是想通过TRUNCATE清理空间,结果发现TRUNCATE 之后,SEGMENT 的大小并没有改变。

查询发现,是由于该表的INITIAL_EXTENT本来就很大

SQL> select TABLE_NAME,INITIAL_EXTENT from dba_tables where TABLE_NAME='TRANLOG_201610'; TABLE_NAME                    INITIAL_EXTENT ------------------------------ -------------- TRANLOG_201610                    1409286144 TRANLOG_201610                          65536

那到底是为什么这个INITIAL_EXTENT这么大呢?

查询了一下该表的建表语句

 select dbms_metadata.get_ddl('TABLE','TRANLOG_201610','ECITY') mb  from dual;   CREATE TABLE "ECITY"."TRANLOG_201610"   (  "MERID" CHAR(3) NOT NULL ENABLE,   "ORDERNO" VARCHAR2(64) NOT NULL ENABLE,   .......   USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS   STORAGE(INITIAL 226492416 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645   PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)   TABLESPACE "TS_ECITYDB"  ENABLE   ) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING   STORAGE(INITIAL 1409286144 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645   PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)   TABLESPACE "TS_ECITYDB"

可以看到,建表的时候,这个INITIAL 设置太大了

SQL> select 1409286144/1024/1024 from dual; 1409286144/1024/1024 --------------------                 1344 SQL> ALTER TABLE ECITY.TRANLOG_201610 MOVE STORAGE(INITIAL 65536 NEXT 65536); Table altered. SQL> select TABLE_NAME,INITIAL_EXTENT/1024/1024 MB from dba_tables where TABLE_NAME='TRANLOG_201610'; TABLE_NAME                            MB ------------------------------ --------------- TRANLOG_201610                        0 TRANLOG_201610                        0 SQL>

进行这个操作之后,会让索引失效,记得要重建索引。所以生产环境上慎用!!!

案例测试:

create table t1 (x int CONSTRAINT pk_t  primary key,y number)  STORAGE(INITIAL 1409286144 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT) TABLESPACE "TS_ECITYDB"; create table t1 (x int CONSTRAINT pk_t  primary key,y number)  STORAGE(INITIAL 1409286144 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT) TABLESPACE "TS_ECITYDB" SQL> insert into t1 values (1,1); SQL> insert into t1 values (2,1); SQL> insert into t1 values (3,2); SQL> COMMIT SQL> SELECT B.index_name,B.table_owner,B.table_name,B.status FROM DBA_INDEXES B where table_owner='ECITY' and table_name='T1'; INDEX_NAME                              TABLE_OWNER          TABLE_NAME STATUS ---------------------------------------- -------------------- ---------- ------------------------ PK_T                                    ECITY                T1        VALID T1_Y                                    ECITY                T1        VALID SQL> ALTER TABLE ECITY.T1 MOVE STORAGE(INITIAL 65536 NEXT 65536); Table altered. SQL> SELECT B.index_name,B.table_owner,B.table_name,B.status FROM DBA_INDEXES B where table_owner='ECITY' and table_name='T1'; INDEX_NAME                              TABLE_OWNER          TABLE_NAME STATUS ---------------------------------------- -------------------- ---------- ------------------------ PK_T                                    ECITY                T1        UNUSABLE T1_Y                                    ECITY                T1        UNUSABLE SQL> SQL> SELECT B.index_name,B.table_owner,B.table_name,B.status FROM DBA_INDEXES B where table_owner='ECITY' and table_name='T1'; INDEX_NAME                              TABLE_OWNER          TABLE_NAME STATUS ---------------------------------------- -------------------- ---------- ------------------------ PK_T                                    ECITY                T1        VALID SQL> ALTER TABLE ECITY.T1 MOVE STORAGE(INITIAL 65536 NEXT 65536); Table altered. SQL> SELECT B.index_name,B.table_owner,B.table_name,B.status FROM DBA_INDEXES B where table_owner='ECITY' and table_name='T1'; INDEX_NAME                              TABLE_OWNER          TABLE_NAME STATUS ---------------------------------------- -------------------- ---------- ------------------------ PK_T                                    ECITY                T1        UNUSABLE SQL> SELECT B.index_name,B.table_owner,B.table_name,B.status FROM DBA_INDEXES B where status='UNUSABLE' and table_owner='ECITY'; SELECT DISTINCT 'ALTER INDEX ' || INDEX_NAME || ' REBUILD;' FROM DBA_INDEXES B where status='UNUSABLE' and table_owner='ECITY';

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档