ITPub博客

首页 > 数据库 > Oracle > 一个表空间有多个数据文件,新增数据时的写入顺序和分配算法初探实验(上)

一个表空间有多个数据文件,新增数据时的写入顺序和分配算法初探实验(上)

原创 Oracle 作者:bfc99 时间:2014-02-15 11:38:53 0 删除 编辑
当一个表空间中有多个数据文件,新增数据时,会写到哪个数据文件上呢?有人说是由ORACLE随机控制,即是根据一个分配算法计算后,将新增的数据写入到指定的一个或多个数据文件上。但这个算法是什么,一直也没有找到相关的说明。下面的这个实验,算是对这个算法的一个初步探寻吧,供大家参考。
实验设想:
所有实验在ORACLE DATABASE 10.2.0.5上完成,操作系统为Linux localhost.localdomain 2.6.18-194.el5 。创建的表空间均为本地自动管理。
情景1:创建两个非自动扩展的的数据文件,创建测试用表,向测试用表中插入数据,观察这两个数据文件的空间使用情况。然后增加一个同样大小的自动扩展的数据文件后,继续向测试用表中插入数据,观察这三个数据文件的空间使用情况。再增加一个同样大小的非自动扩展的数据文件后,继续向测试用表中插入数据,并观察四个数据文件的空间使用情况。
SQL> create tablespace demo datafile '/oradata/orcl/demo01.dbf' size 2M autoextend off,'/oradata/orcl/demo02.dbf' size 2M autoextend off;


Tablespace created.


SQL> select * from dba_data_files where tablespace_name='DEMO';


FILE_NAME  FILE_ID TABLESPACE  BYTES     BLOCKS STATUS    RELATIVE_FNO AUT MAXBYTES  MAXBLOCKS INCREMENT_BY USER_BYTES USER_BLOCKS ONLINE_
------------------------------ ---------- ---------- ---------- ---------- --------- ------------ --- ---------- ---------- ------------ ---------- ----------- -------
/oradata/orcl/demo01.dbf 6 DEMO 2097152        256 AVAILABLE 6 NO       0  0       0    2031616    248 ONLINE
/oradata/orcl/demo02.dbf 8 DEMO 2097152        256 AVAILABLE 8 NO       0  0       0    2031616    248 ONLINE


检查DEMO表空间的管理方式,确认为本地自动管理。
SQL> select tablespace_name,block_size,initial_extent,next_extent,min_extents,max_extents,extent_management,allocation_type from dba_tablespaces where tablespace_name='DEMO';


TABLESPACE BLOCK_SIZE INITIAL_EXTENT NEXT_EXTENT MIN_EXTENTS MAX_EXTENTS EXTENT_MAN ALLOCATIO
---------- ---------- -------------- ----------- ----------- ----------- ---------- ---------
DEMO 8192       65536   1  2147483645 LOCAL    SYSTEM


创建测试用表,并插入1000行记录
SQL> create table demo_table tablespace demo as select * from dba_objects where 1=2;


Table created.


SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


查看当前空间使用情况
SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES
-------------------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8    0       9      65536
DEMO_TABLE     DEMO 8    1      17      65536


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6       9    2031616   248  6
DEMO    8      25    1900544   232  8


如上所示,1000行记当占用了两个区,共16个数据块,每个区由8个数据块组成,共占用了16个数据块。每个数据块8K,共占用了128K的空间。但这128K的空间全部来自于FILE_ID为8的数据文件。


我们继续插入1000行。
SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES
-------------------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8    0       9      65536
DEMO_TABLE     DEMO 8    1      17      65536
DEMO_TABLE     DEMO 8    2      25      65536
DEMO_TABLE     DEMO 8    3      33      65536


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6       9    2031616   248  6
DEMO    8      41    1769472   216  8


仍然是使用8号文件。继续插入数据。
SQL> select count(1) from demo_table;


  COUNT(1)
----------
      8000
已经插入了8000行(前面插入数据的过程略去)
再插入数据1000行。
SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6       9    2031616   248  6
DEMO    8     129    1048576   128  8


可以看到,这时仍只是使用8号文件,6号文件一直未使用。
再插入数据1000行。
SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8


变化了,开始使用6号文件了,而且一下子就用了128个数据块,并且,两个数据文件目前的可用数据块数量是相等的。或者说,两个文件的可用空间是相同的。
那我们看一下6号文件中的这些数据块是如何分配的。
SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes,blocks from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 6   16       9    1048576   128
DEMO_TABLE     DEMO 8    0       9      65536     8
DEMO_TABLE     DEMO 8    1      17      65536     8
DEMO_TABLE     DEMO 8    2      25      65536     8
DEMO_TABLE     DEMO 8    3      33      65536     8
DEMO_TABLE     DEMO 8    4      41      65536     8
DEMO_TABLE     DEMO 8    5      49      65536     8
DEMO_TABLE     DEMO 8    6      57      65536     8
DEMO_TABLE     DEMO 8    7      65      65536     8
DEMO_TABLE     DEMO 8    8      73      65536     8
DEMO_TABLE     DEMO 8    9      81      65536     8


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8   10      89      65536     8
DEMO_TABLE     DEMO 8   11      97      65536     8
DEMO_TABLE     DEMO 8   12     105      65536     8
DEMO_TABLE     DEMO 8   13     113      65536     8
DEMO_TABLE     DEMO 8   14     121      65536     8
DEMO_TABLE     DEMO 8   15     129      65536     8


17 rows selected.


如上所示,6号文件上只使用了一个extent(区ID为16),但这个区总共占用了128个数据块。


我们再插入数据1000行看看。


SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8


SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes,blocks from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 6   16       9    1048576   128
DEMO_TABLE     DEMO 8    0       9      65536     8
DEMO_TABLE     DEMO 8    1      17      65536     8
DEMO_TABLE     DEMO 8    2      25      65536     8
DEMO_TABLE     DEMO 8    3      33      65536     8
DEMO_TABLE     DEMO 8    4      41      65536     8
DEMO_TABLE     DEMO 8    5      49      65536     8
DEMO_TABLE     DEMO 8    6      57      65536     8
DEMO_TABLE     DEMO 8    7      65      65536     8
DEMO_TABLE     DEMO 8    8      73      65536     8
DEMO_TABLE     DEMO 8    9      81      65536     8


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8   10      89      65536     8
DEMO_TABLE     DEMO 8   11      97      65536     8
DEMO_TABLE     DEMO 8   12     105      65536     8
DEMO_TABLE     DEMO 8   13     113      65536     8
DEMO_TABLE     DEMO 8   14     121      65536     8
DEMO_TABLE     DEMO 8   15     129      65536     8


17 rows selected.


数据文件上的可用空间没有变化,区和块的使用上,也和插入前是一样的。说明新插入的数据仍然是在向6号文件中写入(写入到上次分配的128个数据块中的空闲块中)。
我们继续插入数据,看看6号文件分配的这128个数据块用满后会是什么情况。
SQL> select count(1) from demo_table;


  COUNT(1)
----------
     19000


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8


SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8


SQL> insert into demo_table select * from dba_objects where rownum<=1000;
insert into demo_table select * from dba_objects where rownum<=1000
*
ERROR at line 1:
ORA-01653: unable to extend table SYS.DEMO_TABLE by 128 in tablespace DEMO


报错了,提示不能为表DEMO_TABLE以128个数据块来扩展表空间DEMO了。
但实际上,两个数据文件中空闲的数据块合计有240(120+120)个。
我们再看看此时区和块的使用情况。
SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes,blocks from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 6   16       9    1048576   128
DEMO_TABLE     DEMO 8    0       9      65536     8
DEMO_TABLE     DEMO 8    1      17      65536     8
DEMO_TABLE     DEMO 8    2      25      65536     8
DEMO_TABLE     DEMO 8    3      33      65536     8
DEMO_TABLE     DEMO 8    4      41      65536     8
DEMO_TABLE     DEMO 8    5      49      65536     8
DEMO_TABLE     DEMO 8    6      57      65536     8
DEMO_TABLE     DEMO 8    7      65      65536     8
DEMO_TABLE     DEMO 8    8      73      65536     8
DEMO_TABLE     DEMO 8    9      81      65536     8


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8   10      89      65536     8
DEMO_TABLE     DEMO 8   11      97      65536     8
DEMO_TABLE     DEMO 8   12     105      65536     8
DEMO_TABLE     DEMO 8   13     113      65536     8
DEMO_TABLE     DEMO 8   14     121      65536     8
DEMO_TABLE     DEMO 8   15     129      65536     8


17 rows selected.


和前面没有区别和变化。
现在追加一个可自动扩展的数据文件到DEMO表空间。
SQL> alter tablespace demo add datafile '/oradata/orcl/demo03.dbf' size 2M autoextend on;


Tablespace altered.


SQL> select * from dba_data_files where tablespace_name='DEMO';


FILE_NAME  FILE_ID TABLESPACE  BYTES     BLOCKS STATUS    RELATIVE_FNO AUT MAXBYTES  MAXBLOCKS INCREMENT_BY USER_BYTES USER_BLOCKS ONLINE_
------------------------------ ---------- ---------- ---------- ---------- --------- ------------ --- ---------- ---------- ------------ ---------- ----------- -------
/oradata/orcl/demo01.dbf 6 DEMO 2097152        256 AVAILABLE 6 NO       0  0       0    2031616    248 ONLINE
/oradata/orcl/demo02.dbf 8 DEMO 2097152        256 AVAILABLE 8 NO       0  0       0    2031616    248 ONLINE
/oradata/orcl/demo03.dbf 9 DEMO 2097152        256 AVAILABLE 9 YES 3.4360E+10    4194302       1    2031616    248 ONLINE


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8
DEMO    9       9    2031616   248  9


继续向DEMO_TABLE中插入数据1000行。


SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8
DEMO    9     137     983040   120  9


SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes,blocks from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 6   16       9    1048576   128
DEMO_TABLE     DEMO 8    0       9      65536     8
DEMO_TABLE     DEMO 8    1      17      65536     8
DEMO_TABLE     DEMO 8    2      25      65536     8
DEMO_TABLE     DEMO 8    3      33      65536     8
DEMO_TABLE     DEMO 8    4      41      65536     8
DEMO_TABLE     DEMO 8    5      49      65536     8
DEMO_TABLE     DEMO 8    6      57      65536     8
DEMO_TABLE     DEMO 8    7      65      65536     8
DEMO_TABLE     DEMO 8    8      73      65536     8
DEMO_TABLE     DEMO 8    9      81      65536     8


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8   10      89      65536     8
DEMO_TABLE     DEMO 8   11      97      65536     8
DEMO_TABLE     DEMO 8   12     105      65536     8
DEMO_TABLE     DEMO 8   13     113      65536     8
DEMO_TABLE     DEMO 8   14     121      65536     8
DEMO_TABLE     DEMO 8   15     129      65536     8
DEMO_TABLE     DEMO 9   17       9    1048576   128


18 rows selected.


如上所示,ORACLE直接在新增加的文件上占用了128个数据块。
下面我们试试插入1万行,把这128个数据块占满,需要再分配新的区时,情况是什么样子。
SQL> insert into demo_table select * from dba_objects where rownum<=10000;


10000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8
DEMO    9     265     983040   120  9


SQL> select * from dba_data_files where tablespace_name='DEMO';


FILE_NAME  FILE_ID TABLESPACE  BYTES     BLOCKS STATUS    RELATIVE_FNO AUT MAXBYTES  MAXBLOCKS INCREMENT_BY USER_BYTES USER_BLOCKS ONLINE_
------------------------------ ---------- ---------- ---------- ---------- --------- ------------ --- ---------- ---------- ------------ ---------- ----------- -------
/oradata/orcl/demo01.dbf 6 DEMO 2097152        256 AVAILABLE 6 NO       0  0       0    2031616    248 ONLINE
/oradata/orcl/demo02.dbf 8 DEMO 2097152        256 AVAILABLE 8 NO       0  0       0    2031616    248 ONLINE
/oradata/orcl/demo03.dbf 9 DEMO 3145728        384 AVAILABLE 9 YES 3.4360E+10    4194302       1    3080192    376 ONLINE


如上,可自动扩展的数据文件产生了空间扩展。
SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes,blocks from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 6   16       9    1048576   128
DEMO_TABLE     DEMO 8    0       9      65536     8
DEMO_TABLE     DEMO 8    1      17      65536     8
DEMO_TABLE     DEMO 8    2      25      65536     8
DEMO_TABLE     DEMO 8    3      33      65536     8
DEMO_TABLE     DEMO 8    4      41      65536     8
DEMO_TABLE     DEMO 8    5      49      65536     8
DEMO_TABLE     DEMO 8    6      57      65536     8
DEMO_TABLE     DEMO 8    7      65      65536     8
DEMO_TABLE     DEMO 8    8      73      65536     8
DEMO_TABLE     DEMO 8    9      81      65536     8


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8   10      89      65536     8
DEMO_TABLE     DEMO 8   11      97      65536     8
DEMO_TABLE     DEMO 8   12     105      65536     8
DEMO_TABLE     DEMO 8   13     113      65536     8
DEMO_TABLE     DEMO 8   14     121      65536     8
DEMO_TABLE     DEMO 8   15     129      65536     8
DEMO_TABLE     DEMO 9   17       9    1048576   128
DEMO_TABLE     DEMO 9   18     137    1048576   128


19 rows selected.
新分配的区被写在了文件9上。
我们现在按计划,再添加一个非自动扩展的数据文件,看看新分配的区会写到可扩展的文件上,还是这个新添加的不可扩展的新数据文件上。


SQL> alter tablespace demo add datafile '/oradata/orcl/demo04.dbf' size 2M autoextend off;


Tablespace altered.


SQL> select * from dba_data_files where tablespace_name='DEMO';


FILE_NAME  FILE_ID TABLESPACE  BYTES     BLOCKS STATUS    RELATIVE_FNO AUT MAXBYTES  MAXBLOCKS INCREMENT_BY USER_BYTES USER_BLOCKS ONLINE_
------------------------------ ---------- ---------- ---------- ---------- --------- ------------ --- ---------- ---------- ------------ ---------- ----------- -------
/oradata/orcl/demo01.dbf 6 DEMO 2097152        256 AVAILABLE 6 NO       0  0       0    2031616    248 ONLINE
/oradata/orcl/demo02.dbf 8 DEMO 2097152        256 AVAILABLE 8 NO       0  0       0    2031616    248 ONLINE
/oradata/orcl/demo03.dbf 9 DEMO 3145728        384 AVAILABLE 9 YES 3.4360E+10    4194302       1    3080192    376 ONLINE
/oradata/orcl/demo04.dbf       10 DEMO 2097152        256 AVAILABLE       10 NO       0  0       0    2031616    248 ONLINE


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8
DEMO    9     265     983040   120  9
DEMO   10       9    2031616   248 10


SQL> select count(*) from demo_table;


  COUNT(*)
----------
     31000
现在表中有31000行,根据我们前面实验的经验,差不多128个数据块可以存放10000行记录。为了加快实验速度,我们直接把记录增加到4万行。
继续向测试表中插入数据9000行。
SQL> insert into demo_table select * from dba_objects where rownum<=9000;


9000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8
DEMO    9     265     983040   120  9
DEMO   10       9    2031616   248 10


SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes,blocks from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 6   16       9    1048576   128
DEMO_TABLE     DEMO 8    0       9      65536     8
DEMO_TABLE     DEMO 8    1      17      65536     8
DEMO_TABLE     DEMO 8    2      25      65536     8
DEMO_TABLE     DEMO 8    3      33      65536     8
DEMO_TABLE     DEMO 8    4      41      65536     8
DEMO_TABLE     DEMO 8    5      49      65536     8
DEMO_TABLE     DEMO 8    6      57      65536     8
DEMO_TABLE     DEMO 8    7      65      65536     8
DEMO_TABLE     DEMO 8    8      73      65536     8
DEMO_TABLE     DEMO 8    9      81      65536     8


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8   10      89      65536     8
DEMO_TABLE     DEMO 8   11      97      65536     8
DEMO_TABLE     DEMO 8   12     105      65536     8
DEMO_TABLE     DEMO 8   13     113      65536     8
DEMO_TABLE     DEMO 8   14     121      65536     8
DEMO_TABLE     DEMO 8   15     129      65536     8
DEMO_TABLE     DEMO 9   17       9    1048576   128
DEMO_TABLE     DEMO 9   18     137    1048576   128


19 rows selected.


SQL> select count(*) from demo_table;


  COUNT(*)
----------
     40000
     


如上所示,这时并未发生新的区的分配。如果这里再插入数据1000行,就会发生新的区的分配了。


SQL> insert into demo_table select * from dba_objects where rownum<=1000;


1000 rows created.


SQL> select * from dba_free_space where tablespace_name='DEMO' order by file_id;


TABLESPACE    FILE_ID BLOCK_ID      BYTES BLOCKS RELATIVE_FNO
---------- ---------- ---------- ---------- ---------- ------------
DEMO    6     137     983040   120  6
DEMO    8     137     983040   120  8
DEMO    9     265     983040   120  9
DEMO   10     137     983040   120 10


在新添加的10号数据文件上为新区进行了分配。


SQL> select segment_name,tablespace_name,file_id,extent_id,block_id,bytes,blocks from dba_extents where tablespace_name='DEMO' order by file_id,extent_id,block_id;


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 6   16       9    1048576   128
DEMO_TABLE     DEMO 8    0       9      65536     8
DEMO_TABLE     DEMO 8    1      17      65536     8
DEMO_TABLE     DEMO 8    2      25      65536     8
DEMO_TABLE     DEMO 8    3      33      65536     8
DEMO_TABLE     DEMO 8    4      41      65536     8
DEMO_TABLE     DEMO 8    5      49      65536     8
DEMO_TABLE     DEMO 8    6      57      65536     8
DEMO_TABLE     DEMO 8    7      65      65536     8
DEMO_TABLE     DEMO 8    8      73      65536     8
DEMO_TABLE     DEMO 8    9      81      65536     8


SEGMENT_NAME     TABLESPACE    FILE_ID  EXTENT_ID BLOCK_ID      BYTES BLOCKS
-------------------- ---------- ---------- ---------- ---------- ---------- ----------
DEMO_TABLE     DEMO 8   10      89      65536     8
DEMO_TABLE     DEMO 8   11      97      65536     8
DEMO_TABLE     DEMO 8   12     105      65536     8
DEMO_TABLE     DEMO 8   13     113      65536     8
DEMO_TABLE     DEMO 8   14     121      65536     8
DEMO_TABLE     DEMO 8   15     129      65536     8
DEMO_TABLE     DEMO 9   17       9    1048576   128
DEMO_TABLE     DEMO 9   18     137    1048576   128
DEMO_TABLE     DEMO 10   19       9    1048576   128


20 rows selected.


如上所示,在10号文件上,分配了一个新区,新区大小128个数据块。


综上,可以得出以下几个观点:
1、当初始创建表空间后,ORACLE会首先向FILE_ID最大的数据文件中写入。
2、区的大小不是不变的,初始是每区8个块,但随后就增加到每区128个数据块。
3、数据文件中剩余的连续块若不够128个,即不够一个新区的需要的块数量时,空间是浪费的。


疑问:由于这个实验中的数据文件起始大小过小,非自动扩展的数据文件中已不能容纳一个新的区(128个数据块),所以,再新增加的区只能是写到新追加的数据文件或是对可扩展的数据文件进行扩展。那么,如果非自动扩展的数据文件可以容纳下一个新的区,情况会是什么样子呢?
为此,在下面的实验中,我们将初始文件的大小由2M,改为4M。
同时,为了保证实验的一致性,我们将当前的表空间及其内容和数据文件全部删除。

本实验的后半部分请见 http://blog.itpub.net/22207394/viewspace-1081774/


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22207394/viewspace-1081775/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2014-01-02

  • 博文量
    79
  • 访问量
    571911