oracle数据库 修改表空间数据文件大小,优化存储

简介: oracle数据库 修改表空间数据文件大小,优化存储

查询数据文件存储使用情况

/**  示例1 只查询*/

select b.file_id  文件ID,

        b.tablespace_name  表空间,

        b.file_name     物理文件名,

        b.bytes /1024/1024       总字节数,

        (b.bytes -sum(nvl(a.bytes, 0))) /1024/1024   已使用,

        sum(nvl(a.bytes, 0)) /1024/1024        剩余,

        round(sum(nvl(a.bytes, 0)) / (b.bytes) *100, 2)  剩余百分比   from dba_free_space a,

      dba_data_files b   where a.file_id= b.file_id   groupby b.tablespace_name,

      b.file_name,

      b.file_id,

      b.bytes   orderby b.tablespace_name;


/** 示例2 附带查询压缩脚本*/

select a.file#,

a.name,

a.bytes /1024/1024 CurrentMB,

ceil(HWM * a.block_size) /1024/1024 ResizeTo,

(a.bytes - HWM * a.block_size) /1024/1024 ReleaseMB,

'alter database datafile '''|| a.name ||''' resize '||

ceil(HWM * a.block_size) /1024/1024||'M;' ResizeCmd

from v$datafile a,

(SELECTfile_id, MAX(block_id + blocks -1) HWM

FROM DBA_EXTENTS

GROUPBYfile_id) b

where a.file# = b.file_id(+)

And (a.bytes - HWM * a.block_size) >0

and rownum <10

修改数据文件容量语句

alterdatabase datafile 'D:\DSINSTALL\ORACLE\ORADATA\ORCL\USERS_DATA01.DBF' resize 10M;

楼主在此处遇见了一个问题,在清理了一大批数据后,发现表空间的存储大小基本没变,强行修改数据文件大小也不行,会提示“资源正在占用”,后面了解到,在删除数据时最好使用下列语句:

/* 清空表i数据*/

truncatetable table_name;

注:不要使用delete删除,由于oracle自带回滚机制或者oracle处于数据保护机制,使用delete删除的数据oracle会临时保存,类似于假删除/回收站

/* 删除用户及附属数据*/

dropuseruser_name descade;

如果数据表曾经存在大数据情况下,还需要修改表的初始化STORAGE值,语句如下,该语句的含义是修改表/索引的初始值为64k,每次增长的幅度为32k

--

select'ALTER TABLE '||owner||'.'||table_name||' MOVE TABLESPACE '||tablespace_name||' STORAGE(INITIAL 64K NEXT 32K);'

 from dba_tables

where owner='AA'and initial_extent>65536  

 

 

--索引

select'ALTER INDEX '||owner||'.'||index_name||' REBUILD STORAGE(INITIAL 64K NEXT 32K);'

 from dba_indexes

where owner='AA'  and initial_extent>65536

 

 

--分区表

select'ALTER table '||table_owner||'.'||table_name||' MOVE PARTITION '||PARTITION_NAME||' STORAGE(INITIAL 64K NEXT 32K);'  

 from DBA_tab_PARTITIONS

where table_owner='AA'and initial_extent>65536

 

 

--分区索引

select'ALTER INDEX '||index_owner||'.'||index_name||' REBUILD PARTITION '||PARTITION_NAME||' STORAGE(INITIAL 64K NEXT 32K);'  

 from DBA_ind_PARTITIONS

where index_owner='AA'and initial_extent>65536

清空当前用户数据库表下存储大于1M的表数据脚本查询语句

select

'truncate table '|| segment_name||';',

bytes/1024/1024 MB,

u.*

from user_extents u

where bytes/1024/1024>1

查询数据库中各个表的实际数据存储使用情况

select

segment_name, sum(bytes)/1024/1024 MB

from user_extents u

groupby segment_name




















相关文章
|
4天前
|
存储 Oracle NoSQL
Oracle 表空间、数据文件、schema的关系
Oracle 表空间、数据文件、schema的关系
16 2
|
6天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库:装上去,飞起来!
本文是一篇关于Oracle数据库安装和使用的博文摘要。作者以轻松幽默的笔调介绍了自己在实验中掌握的Oracle数据库基本操作,包括使用组件查看命令、配置数据库监听器等。作者也分享了在实验中遇到的一些有趣问题,如SQL语句缺少分号导致的意外错误。此外,作者还强调了登录sys用户和启动实例加载数据库的注意事项,并鼓励读者面对挑战时保持乐观,不断提升自己的能力。整体风格风趣严谨,引人入胜。
63 0
|
6天前
|
存储 运维 关系型数据库
数据的力量:构筑现代大型网站之数据库基础与应用
数据的力量:构筑现代大型网站之数据库基础与应用
176 0
|
2天前
|
存储 NoSQL MongoDB
|
1天前
|
SQL 监控 Java
Java Web应用中数据库连接池的配置与优化
Java Web应用中数据库连接池的配置与优化
|
1天前
|
开发框架 Oracle 关系型数据库
ASP.NET实验室LIS系统源码 Oracle数据库
LIS是HIS的一个组成部分,通过与HIS的无缝连接可以共享HIS中的信息资源,使检验科能与门诊部、住院部、财务科和临床科室等全院各部门之间协同工作。 
15 4
|
2天前
|
Oracle 关系型数据库 数据处理
某教程学习笔记(一):10、oracle数据库注入
某教程学习笔记(一):10、oracle数据库注入
4 0
|
2天前
|
SQL 关系型数据库 MySQL
Python爬虫之关系型数据库存储#5
python MySQL 增删改查操作
9 1
|
3天前
|
存储 缓存 NoSQL
《优化数据库性能的关键技巧》
在当今信息爆炸的时代,数据库扮演着至关重要的角色。本文将分享一些关键的技巧,帮助开发人员优化数据库性能,提升系统的响应速度和稳定性。
|
17天前
|
关系型数据库 MySQL 数据库
MySQL员工打卡日志表——数据库练习
MySQL员工打卡日志表——数据库练习
19 0

热门文章

最新文章

推荐镜像

更多