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




















相关文章
|
2天前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
94 64
|
2天前
|
存储 缓存 监控
数据库优化技术:提升性能与效率的关键策略
【10月更文挑战第15天】数据库优化技术:提升性能与效率的关键策略
23 8
|
1天前
|
监控 Oracle 关系型数据库
Oracle数据库性能优化
【10月更文挑战第16天】Oracle数据库性能优化是
5 1
|
8天前
|
存储 Oracle 关系型数据库
【数据库-Oracle】《Oracle 数据库探秘:基础知识点全攻略》
《Oracle 数据库探秘:基础知识点全攻略》深入介绍 Oracle 数据库的基础知识点,包括数据类型、表结构、查询语句等。通过详细讲解、代码示例和流程图,帮助读者快速掌握 Oracle 数据库的基本操作,为数据库开发和管理打下坚实基础。
19 0
|
9天前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
43 6
|
7天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
39 3
Mysql(4)—数据库索引
|
9天前
|
SQL Ubuntu 关系型数据库
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
本文为MySQL学习笔记,介绍了数据库的基本概念,包括行、列、主键等,并解释了C/S和B/S架构以及SQL语言的分类。接着,指导如何在Windows和Ubuntu系统上安装MySQL,并提供了启动、停止和重启服务的命令。文章还涵盖了Navicat的使用,包括安装、登录和新建表格等步骤。最后,介绍了MySQL中的数据类型和字段约束,如主键、外键、非空和唯一等。
27 3
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
|
14天前
|
缓存 算法 关系型数据库
Mysql(3)—数据库相关概念及工作原理
数据库是一个以某种有组织的方式存储的数据集合。它通常包括一个或多个不同的主题领域或用途的数据表。
38 5
Mysql(3)—数据库相关概念及工作原理
|
1天前
|
存储 关系型数据库 MySQL
如何在MySQL中创建数据库?
【10月更文挑战第16天】如何在MySQL中创建数据库?
|
5天前
|
SQL Oracle 关系型数据库
安装最新 MySQL 8.0 数据库(教学用)
安装最新 MySQL 8.0 数据库(教学用)
34 4

推荐镜像

更多