中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

TRUNCATE TABLE后 SEGMENT_SIZE沒變 ?

發布時間:2020-06-24 12:11:07 來源:網絡 閱讀:858 作者:莫廣學 欄目:關系型數據庫

測試環境中,歷史的交易表可以清空,僅需保留表結構。

于是想通過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';


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

景东| 株洲市| 陈巴尔虎旗| 咸宁市| 于都县| 许昌县| 会同县| 丹东市| 马公市| 通山县| 屏东县| 鄢陵县| 安新县| 息烽县| 吕梁市| 保靖县| 中卫市| 苏州市| 华蓥市| 阿克陶县| 中牟县| 石阡县| 专栏| 确山县| 蕲春县| 安多县| 隆安县| 永寿县| 荔浦县| 会泽县| 万盛区| 休宁县| 久治县| 教育| 翁牛特旗| 南昌县| 定远县| 治多县| 永城市| 达尔| 广东省|