oracle可视化工具IB,oracle小记:dba_data_files

今天给表空间扩展的时候,使用了dba_data_files进行查询。查阅了网上的资料。

该系统系统中含有以下字段

433872c8ac584c9aa10e4858616a162e.png

每个字段的含义如下:

e3be5faae4b60fc67b544d170cc42871.png

2019/11/22号更新:

今天发现了一个问题。我查阅表空间的时候,发现MAXBYTES 比 BYTES 的空间要小。 字段含义的翻译:MAXBYTES 为‘如果可以扩展,最大可以到多大’。 然后我发现了BYTES 的容量已经比MAXBYTES大很多了。如下图:

1ddf10e41f178ade8e069f576f656aa5.png

这时候,难道不是违背了字段的含义了吗?

这是我查阅了资料和网上的博客,我发现了一个解答

很多人的博客上面都是这样一句话 :‘DBA_DATA_FILES中bytes的值要比maxbytes的值要大

来源于:

Value in BYTES Column Greater than MAXBYTES Column in DBA_DATA_FILES (文档 ID 197244.1)’

拜托这么写,谁知道是啥来源。。。

0b11f3400b1d0622d215505863a39d05.png

这是来自oracle官方的一篇文章。

文章里面有这样的一句话‘The BYTES column in DBA_DATA_FILES has a value greater than MAXBYTES column when a datafile was manually resized to a value GREATER than MAXSIZE (MAXBYTES).’

描述:

当一个datafile 手工resize到一个大于maxsize(maxbytes)的值之后,DBA_DATA_FILES中bytes的值要比maxbytes的值要大,当该datafile被设置为autoextend on之后,dba_data_files中的maxbytes 值被自动结算为一个非零值。dba_data_files中的bytes是该datafile的当前的大小(以bytes为单位)

手动resize数据文件会导致这一现象。

实验:

步骤1:新建数据文件,初始化5M,最大20M,自动扩展YES

fe235bf01070b6bb2726e88c7386ea41.png

步骤2:修改该数据文件大小为50M

alter database datafile '/opt/ora11/product/oradata/dms/data02.dbf' resize 50M;

d5203e1bb90843ad8197980a90954b03.png

此时出现bytes>maxbytes情况

步骤三:插入数据测试是否能自动扩展

e49be2d780670eb79d8b6e910cd1729b.png

提示无法扩展

步骤四:查询DATA表空间剩余大小

3c9803f5420131183ff31b3bb25b2219.png

结论:

autoextend=NO时:maxbytes为0,bytes即为该数据文件的初始化大小,也为该文件最大大小。

autoextend=YES时:如果bytes>maxbytes,则说明该数据文件进行了resize,resize即为该数据文件可使用的最大大小,即使没有达到32G,也无法自动扩展

如果bytes=maxbytes,则该数据文件可使用大小为bytes的值,无法扩展(受maxbytes限制)

tips: 还看到一个网上的案例:

下面是一个示例:

解释:

当datafile 被resize的时候,dba_data_files中的maxbytes 值 不会被更新,此时被更新的列只是bytes列。

dba_data_files中的maxbytes 值是在使用ALTER DATABASE command with MAXSIZE option 时才会被更新的。

Step-1: Createa New Tablespace====== =======================SQL> createtablespace tst2 datafile 'd:\oracle\tst01.dbf' size 5m autoextend on;

Tablespace created.

SQL> select file_name, bytes, maxbytes, autoextensible fromdba_data_files;FILE_NAMEBYTES MAXBYTES AUT---------------------------------------- ---------- ---------- ---

D:\ORACLE\TST01.DBF 5242880 1.7180E+10YES1rows selected.

Step-2: Alter the MAXSIZE value from defaultvalue====== ==========================================SQL> alter database datafile 'd:\oracle\tst01.dbf' autoextend onmaxsize 10m;Databasealtered.

SQL> select file_name, bytes, maxbytes,a utoextensible fromdba_data_files;FILE_NAMEBYTES MAXBYTES AUT---------------------------------------- ---------- ---------- ---

D:\ORACLE\TST01.DBF 5242880 10485760YES1rows selected.

Step-3: Resize the datafile toa value higher than MAXBYTES====== ===================================================SQL> alter database datafile 'd:\oracle\tst01.dbf'resize 20m;Databasealtered.

SQL> select file_name, bytes, maxbytes, autoextensible fromdba_data_files;FILE_NAMEBYTES MAXBYTES AUT---------------------------------------- ---------- ---------- ---

D:\ORACLE\TST01.DBF 20971520 10485760YES1rows selected.

The valuein BYTES column isGREATER than MAXBYTES.

参考:

Note:182097.1 SYS.FILE$ does not display the correct size for locally managed tablespace files

题话外:此时,该datafile(D:\ORACLE\TST01.DBF)能达到的最大大小是dba_data_files.bytes的值。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值