TRUNCATE TABLE后 SEGMENT_SIZE没变 ?
发表于:2024-12-04 作者:千家信息网编辑
千家信息网最后更新 2024年12月04日,测试环境中,历史的交易表可以清空,仅需保留表结构。于是想通过TRUNCATE清理空间,结果发现TRUNCATE 之后,SEGMENT 的大小并没有改变。查询发现,是由于该表的INITIAL_EXTEN
千家信息网最后更新 2024年12月04日TRUNCATE TABLE后 SEGMENT_SIZE没变 ?
测试环境中,历史的交易表可以清空,仅需保留表结构。
于是想通过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 1409286144TRANLOG_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-------------------- 1344SQL> 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 0TRANLOG_201610 0SQL>
进行这个操作之后,会让索引失效,记得要重建索引。所以生产环境上慎用!!!
案例测试:
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> COMMITSQL> 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 VALIDT1_Y ECITY T1 VALIDSQL> 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 UNUSABLET1_Y ECITY T1 UNUSABLESQL> 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 VALIDSQL> 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 UNUSABLESQL>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';
环境
索引
查询
测试
很大
仅需
历史
大小
时候
案例
空间
结构
结果
语句
交易
生产
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全自动监控
软件开发是否进在建工程
超图 数据库工作空间
天龙八部紫禁之巅是什么服务器
陕西智能边缘计算服务器价格多少
安卓系统下的软件开发
互联网科技刷脸技术
数据库数据让数据不为负数
网络安全事件分为哪7项
江宁区网络安全宣讲进校园竞赛
软件工程和软件开发
都有什么服务器
网络技术的崛起
mac 126发件服务器
国家电网信息网络安全八不准
高一计算机网络技术答案
软件开发流程图 泳
江苏省通信与网络技术工程
Mimic数据库一键配置代码
房山回收二手服务器价格查询
自学网络安全工程师推荐
uos软件开发工具
传统数据库名字有哪三种
华为台式机和服务器主板哪个好
淮北工程管理软件开发定制
俄罗斯浪潮服务器
手机斗牛作弊软件开发
软件开发过程中最难的部分
四川卫星授时数显钟服务器
山西牛云网络技术有限公司