Oracle dba_data_files数据字典里的bytes大于maxbytes

今天临下班时,同学发来一个截图,意思是说dba_data_files里的bytes值大于maxbytes值。截图如下:

立马感觉就不好了,根据以往的Oracle运维经验觉得这绝对是不可能的。但是数据查出来的事实就是这样的。于是上百度搜相关问题,无耐搜出来的都是不太相关的资料。于是直接上MOS找资料,还真有一篇是介绍这个的Value in BYTES Column Greater than MAXBYTES Column in DBA_DATA_FILES (文档 ID 197244.1) 其中有这么一句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).那现在明白了,手动resize数据文件会导致这一现象。

下面动手还原一下

本次测试的平台为11.2.0.3

--创建一个测试表空间
SQL> create tablespace zx1 datafile ‘/opt/bboss/tst4/oracle/arch/zx1.dbf‘ size 10M;

Tablespace created.
--查看数据文件的属性
SQL> col file_name for a100
SQL> set linesize 200
SQL> set num 20
SQL> select file_name,tablespace_name,bytes,maxbytes,autoextensible from dba_data_files where tablespace_name=‘ZX1‘;

FILE_NAME                                                                                            TABLESPACE_NAME                     BYTES   MAXBYTES AUT
---------------------------------------------------------------------------------------------------- ------------------------------ ---------- ---------- ---
/opt/bboss/tst4/oracle/arch/zx1.dbf                                                                  ZX1                              10485760          0 NO
--看到默认数据文件的自动增长为NO,bytes也只有创建时指定的10M
--把数据文件转为自动增长
SQL> alter database datafile ‘/opt/bboss/tst4/oracle/arch/zx1.dbf‘ autoextend on;

Database altered.

SQL> select file_name,tablespace_name,bytes,maxbytes,autoextensible from dba_data_files where tablespace_name=‘ZX1‘;

FILE_NAME                                                                                            TABLESPACE_NAME                               BYTES             MAXBYTES AUT
---------------------------------------------------------------------------------------------------- ------------------------------ -------------------- -------------------- ---
/opt/bboss/tst4/oracle/arch/zx1.dbf                                                                  ZX1                                        10485760          34359721984 YES
--看到打开自动增长后MAXBYTES默认为32G,也就是数据文件扩展到32G后就不再扩展
--测试是自动扩展
--创建测试用户及表
SQL> create user zhaoxu identified by zhaoxu;

User created.

SQL> grant connect , resource to zhaoxu;

Grant succeeded.

SQL> create table zhaoxu.test1 tablespace zx1 as select * from dba_objects;

Table created.
--循环插入数据
SQL> begin
  2  for i in 1..100
  3  loop
  4  insert /* append */ into zhaoxu.test1 select * from zhaoxu.test1;
  5  commit;
  6  end loop;
  7  end;
  8  /
begin
*
ERROR at line 1:
ORA-01653: unable to extend table ZHAOXU.TEST1 by 8192 in tablespace ZX1
ORA-06512: at line 4
--执行一段时间后报错,表空间无法扩展
--查看数据文件大小
SQL> select file_name,tablespace_name,bytes,maxbytes,autoextensible from dba_data_files where tablespace_name=‘ZX1‘;

FILE_NAME                                                                                            TABLESPACE_NAME                               BYTES             MAXBYTES AUT
---------------------------------------------------------------------------------------------------- ------------------------------ -------------------- -------------------- ---
/opt/bboss/tst4/oracle/arch/zx1.dbf                                                                  ZX1                                     34293743616          34359721984 YES
--看操作系统上的数据文件大小
SQL> !du -sk /opt/bboss/tst4/oracle/arch/zx1.dbf
33490016        /opt/bboss/tst4/oracle/arch/zx1.dbf
--可以看到数据文件增长没有超过MAXBYTES指定的32G
--此时resize数据文件
SQL> alter database datafile ‘/opt/bboss/tst4/oracle/arch/zx1.dbf‘ resize 33554424k; --由于操作系统限制最大只能33554424k,不过足可以说明问题

Database altered.

SQL> select file_name,tablespace_name,bytes,maxbytes,bytes-maxbytes,autoextensible from dba_data_files where tablespace_name=‘ZX1‘;

FILE_NAME                                                                                            TABLESPACE_NAME                               BYTES             MAXBYTES       BYTES-MAXBYTES AUT
---------------------------------------------------------------------------------------------------- ------------------------------ -------------------- -------------------- -------------------- ---
/opt/bboss/tst4/oracle/arch/zx1.dbf                                                                  ZX1                                     34359730176          34359721984                 8192 YES
--现在看到数据文件的bytes>maxbytes了

上面还原了BYTES>MAXBYTES的过程。

上面提到的表空间的数据文件是自动扩展的,那对于不自动扩展的数据文件又会怎么样呢?

下面继续测试

--取消数据文件的自动扩展
SQL> alter database datafile ‘/opt/bboss/tst4/oracle/arch/zx1.dbf‘ autoextend off;

Database altered.

SQL> select file_name,tablespace_name,bytes,maxbytes,bytes-maxbytes,autoextensible from dba_data_files where tablespace_name=‘ZX1‘;

FILE_NAME                                                                                            TABLESPACE_NAME                               BYTES             MAXBYTES       BYTES-MAXBYTES AUT
---------------------------------------------------------------------------------------------------- ------------------------------ -------------------- -------------------- -------------------- ---
/opt/bboss/tst4/oracle/arch/zx1.dbf                                                                  ZX1                                     34359730176                    0          34359730176 NO
--可以看到MAXBYTES变为了0

如果再把数据文件改为可自动扩展又会出现什么情况呢

SQL> alter database datafile ‘/opt/bboss/tst4/oracle/arch/zx1.dbf‘ autoextend on;

Database altered.

SQL> select file_name,tablespace_name,bytes,maxbytes,bytes-maxbytes,autoextensible from dba_data_files where tablespace_name=‘ZX1‘;

FILE_NAME                                                                                            TABLESPACE_NAME                               BYTES             MAXBYTES       BYTES-MAXBYTES AUT
---------------------------------------------------------------------------------------------------- ------------------------------ -------------------- -------------------- -------------------- ---
/opt/bboss/tst4/oracle/arch/zx1.dbf                                                                  ZX1                                     34359730176          34359730176                    0 YES
--可以看到BYTES=MAXBYTES了

下面总结一下:

dba_data_files数据字典里的bytes值和maxbytes没有什么必然的联系

数据文件不可自动扩展时,MAXBYTES=0,BYTES的值既为该文件已实际分配的大小,也为该为件最大大小

数据文件可自动扩展时,默认的MAXBYTES=32G,BYTES为该文件已实际分配的大小,默认情况下BYTES不会超过MAXBYTES,如果对该文件进行resize操作,那么BYTES就用可能大于MAXBYTES。

时间: 2024-10-19 00:17:04

Oracle dba_data_files数据字典里的bytes大于maxbytes的相关文章

oracle常用数据字典

----常用数据字典 USER_ 记录用户对象的信息,如user_tables包含用户创建的所有表:                                 user_views,user_constraints等; ALL_ 记录用户对象的信息及被授权访问的对象信息: DBA_ 记录数据库实例的所有对象的信息,如DBA_USERS包含数据库实例中 所有用户的信息,DBA的信息包含user和all的信息: V$ 当前实例的动态视图,包含系统管理和优化使用的视图: GV_ 分布环境下所有实

Oracle静态数据字典

select * from user_tab_comments a where a.comments like '%操作%'  数据字典 寻找数据库中注释带有“操作”二字的所有表  静态数据字典 这类数据字典主要是由表和视图组成,应该注意的是,数据字典中的表是不能直接被访问的,但是可以访问数据字典中的视图.静态数据字典中的视图分为三类,它们分别由三个前缀够成:user_*. all_*. dba_*. user_*  该视图存储了关于当前用户所拥有的对象的信息.(即所有在该用户模式下的对象) a

Oracle 之数据字典

1.数据字典是由oracle服务器创建和维护的一组只读系统表,数据字典中存储了有关数据库和数据库对象的信息.数据字典分为两大类:基表和数据字典视图 oracle服务器在数据库创建时通过运行sql.bsp来自动生成这些基表,通过catalog.sql生成数据字典. [[email protected] admin]# ll sql.bsq catalog.sql -rw-r--r--. 1 oracle oinstall 59322 4月 24 2008 catalog.sql -rw-r--r-

转:Oracle中的rownum不能使用大于>的问题

一.对rownum的说明 关于Oracle 的 rownum 问题,很多资料都说不支持SQL语句中的“>.>=.=.between...and”运算符,只能用如下运算符号“<.<=.!=”, 并非说用“>.>=.=.between..and”时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来. 其实,只要理解好了这个 rownum 伪列的意义就不应该感到惊奇. rowid 与 rownum 虽都被称为伪列,但它们的存在方式是不一样的: r

Oracle的数据字典的解释

-- 查询所有的数据字典select * from dictionary; -- 数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的. 比如一个表的创建者信息,创建时间信息,所属表空间信息,用户访问权限信息等. 数据库数据字典是一组表和视图结构.它们存放在SYSTEM表空间中 当用户在对数据库中的数据进行操作时遇到困难就可以访问数据字典来查看详细的信息. 用户可以用SQL语句访问数据库数据字典. 数据字典内容包括: 1,数据库中所有模式对象的信息,如表.视图.簇.及

Oracle之数据字典

数据字典 数据字典是oracle数据库中最重要的组成部分,它提供了数据库的一些系统信息 数据字典记录了数据库的系统信息,它是只读表和视图的集合,数据字典的所有者是sys用户 用户只能在数据字典上执行查询操作,而其维护和修改是由系统自动完成的 数据字典包括数据字典基表和数据字典视图,其中基表存储数据库的基本信息,普通用户不能直接访问数据字典的基表,数据字典视图是基于数据字典基表所建立的视图,普通用户可以通过查询数据字典视图取得系统信息 数据字典视图主要包括:user_xxx,all_xxx,dba

Oracle执行计划里的 access和filter有什么区别

Prediceate(谓词):一个查询中的WHERE限制条件. 在查看执行计划的信息中,经常会看到两个谓词filter和access ,它们的区别是什么,理解了这个两个词对我们解读Oracle的执行计划信息会有所帮助. 简单地说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到过滤的作用. 二.举例说明: ----创建一张表echo---- 1 SQL> create table echo a

转://工作中 Oracle 常用数据字典集锦

DBA工作中数据字典就等同于我们本和笔,时时刻刻也分不开的,不管是看状态,还是监控,都需要数据字典的支持,本文整理出来常用的数据字典系列,帮助大家来记住和汇总以便查询利用 ALL_CATALOG All tables, views, synonyms, sequences accessible to the user  ALL_COL_COMMENTS Comments on columns of accessible tables and views  ALL_COL_GRANTS_MADE 

清理Oracle安装目录里的一些日志信息

最近测试环境服务器上磁盘空间紧张,表空间里面的数据也不知道开发哪些需要哪些不需要,而且因为此测试库运行时间比较久远,起码有三年了.于是就从清理Oracle安装目录下的日志下手. 发现在一般这几个日志,如果没有做定期清理的话,就比较占空间. 1.<user_dump_dest>/alert_<sid>.log 2.$ORACLE_HOME/oc4j/j2ee/OC4J_DBConsole_<hostname>_<SID>/log/http-web-access