阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

TRUNCATE TABLE后 SEGMENT_SIZE没有改变

134次阅读
没有评论

共计 3724 个字符,预计需要花费 10 分钟才能阅读完成。

测试环境中,历史的交易表可以清空,仅需保留表结构。于是想通过 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’;

更多 Oracle 相关信息见 Oracle 专题页面 https://www.linuxidc.com/topicnews.aspx?tid=12

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3724字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中