Oracle学习笔记(1)-------------Oracle体系结构

 终于下定决心来学习Oracle了!

 

上网上找到了一些Oracle的资料,觉得这篇文章写很详细。

本人很懒!只好复制粘贴过来了,作者勿怪!

本文地址http://blog.csdn.net/yujin2010good/article/details/77091200

 

Oracle体系结构就是围绕这张图展开的,要想深入了解oracle,就必须把这张图搞明白。

如图:

 

Oracle学习笔记(1)-------------Oracle体系结构_第1张图片

一、基本组成:

Oracle server:

   一般情况下是一个instance和一个database组成

   1个instance只能对应一个数据库。
    特殊:1个数据库可以有多个instancerac

        一台服务器上同时可装多套版本的数据库软件,每个数据库软件可建多个数据库,但是每个数据库只对应一个instance,也可以理解成每个数据库只有一个SID 。
         利用DBCA建出的每个库都是相对独立的,在同一服务器上如果创建多库必须将环境变量的参数文件做区分,并且在对实例切换时需如下 操作:
                                                                         connect   用户名/密码@实例的服务名

 

 

Oracle Instance:

是由内存(SGA)和后台进程(backupground Process)组成

通过instance来访问database

一个实例只能打开一个数据库

 

Oracle database:

数据文件(Data files):

    数据文件永远存储数据库的数据,包括数据字典、用户数据(表、索引、簇)、undo数据等

重做日志(Redo log):

“先记后写”

重做日志用于记录数据库的变化,当进行例程恢复或介质恢复时需要使用重做日志

执行DDLDML操作时,事物变化会被写到重做日志缓冲区,而在特定的时刻LGWR会将重做日志缓冲区中的内容写入重做日志。

控制文件(Control file

控制文件用于记录和维护数据库的物理结构,并且每个Oracle数据库至少要包含一个控制文件。

归档日志(Archive log:

是非活动(Inactive)重做日志的备份。

口令文件(Password file:

用于验证特权用户(具有SYSDBASYSOPER权限的特殊数据库用户)

参数文件(Parameter file):

用于定义启动实例所需要的初始化参数,包括文本参数文件(pfile)和服务器参数文件(spfile

 

User and Server process :

在执行sql语句时产生的进程,每一个连接,oracle server创建一个session,产生一个server process,在client发起一个connection时就产生了一个user process

 

 

体系结构可以分为,database结构和instance结构

如下结构:

Oracle学习笔记(1)-------------Oracle体系结构_第2张图片

 

 

 二、instance结构详解

  

1、  内存结构

 

主要包括sgasystem global area)和pgaprogram global area

 

Pga是当程序起来时,给server process用(不包含在instance里面,这里不做重点讨论)

 

SGA(System Global Area)由一组内存结构组成,它是由所有用户进程共享的一块内存区域。启动例程时,Oracle自动分配SGA,关闭例程时,oracle自动释放SGA所占用的内存空间。

 Oracle学习笔记(1)-------------Oracle体系结构_第3张图片

下面是dave哥关于sga详解:

http://blog.csdn.net/tianlesoftware/article/details/5594080

Sga包括,share pooldb buffer cacheredo log bufferlarge pooljava pool

9i 中我们都知道在管理Oracle中使用动态SGA时,Granule的大小是和SGA的大小有关系。

SGA 分配的最小单元为一个granule.Oracle SGA的大小总是granule的整数倍,即分配是以整数个granule来分配的。

9i 中的规则如下:

  linux/unix

   SGA <=128 M  granule 4M

   SGA >128M     granule 16M

  Windows

   SGA <=128 M   granule 4M

   SGA >128M     granule 8M

10g 中的分配规则为

  linux/unix

  SGA <=1G   granule 4M

  SGA >1G    granule 16M

  Windows

  SGA <=1G   granule 4M

  SGA >1G     granule 8M

 SQL> select component, granule_size from v$sga_dynamic_components;

COMPONENT                                                        GRANULE_SIZE

---------------------------------------------------------------- ------------

shared pool                                                           4194304

large pool                                                            4194304

java pool                                                             4194304

streams pool                                                          4194304

DEFAULT buffer cache                                                  4194304

KEEP buffer cache                                                     4194304

RECYCLE buffer cache                                                  4194304

DEFAULT 2K buffer cache                                               4194304

DEFAULT 4K buffer cache                                               4194304

DEFAULT 8K buffer cache                                               4194304

DEFAULT 16K buffer cache                                              4194304

DEFAULT 32K buffer cache                                              4194304

ASM Buffer Cache                                                      4194304

 

13 rows selected.

 

Elapsed: 00:00:00.06

 SQL>

 SQL> desc v$sga_dynamic_components;

 Name                   Type

 --------------------------------------------------------

 COMPONENT              VARCHAR2(64)      

 CURRENT_SIZE           NUMBER

 MIN_SIZE               NUMBER

 MAX_SIZE               NUMBER

 USER_SPECIFIED_SIZE    NUMBER

 OPER_COUNT             NUMBER

 LAST_OPER_TYPE         VARCHAR2(13)

 LAST_OPER_MODE         VARCHAR2(9)

 LAST_OPER_TIME         DATE

 GRANULE_SIZE           NUMBER

 SQL>

 SQL>  select * from v$sga_dynamic_components;

COMPONENT            CURRENT_SIZE   MIN_SIZE   MAX_SIZE USER_SPECIFIED_SIZE OPER_COUNT LAST_OPER_TYP LAST_OPER LAST_OPER GRANULE_SIZE

-------------------- ------------ ---------- ---------- ------------------- ---------- ------------- --------- --------- ------------

shared pool              92274688   92274688          0                   0          0 STATIC                                 4194304

large pool                4194304    4194304          0                   0          0 STATIC                                 4194304

java pool                 4194304    4194304          0                   0          0 STATIC                                 4194304

streams pool                    0          0          0                   0          0 STATIC                                 4194304

DEFAULT buffer cache     62914560   62914560          0                   0          0 INITIALIZING                           4194304

KEEP buffer cache               0          0          0                   0          0 STATIC                                 4194304

RECYCLE buffer cache            0          0          0                   0          0 STATIC                                 4194304

DEFAULT 2K buffer ca            0          0          0                   0          0 STATIC                                 4194304

DEFAULT 4K buffer ca            0          0          0                   0          0 STATIC                                 4194304

DEFAULT 8K buffer ca            0          0          0                   0          0 STATIC                                 4194304

DEFAULT 16K buffer c            0          0          0                   0          0 STATIC                                 4194304

DEFAULT 32K buffer c            0          0          0                   0          0 STATIC                                 4194304

ASM Buffer Cache                0          0          0                   0          0 STATIC                                 4194304

 

13 rows selected.

 

 

Buffer Cache Size    

   数据缓存,调高数据命中率可以提高性能。按数据块存放。

     db_cache_size

     db_keep_cache_size

     db_recycle_cache_size

  alter system set db_cache_size = xxx M

 SQL> show parameter advice

NAME_COL_PLUS_SHOW_PARAM    TYPE                 VALUE_COL_PLUS_SHOW_PARAM

--------------------------------------------------------------------------------

db_cache_advice             string               ON

 SQL>

 SQL> select * from v$db_cache_advice;

 SQL>

Large Pool Size        rman 和一些并行处理时候会用到。

Java Pool Size         java存储过程的支持

 

Streams Pool Size          

           

         

          

Oracle 10g sga_target自动调整只是针对这四项:data buffer cache, large_pool, shared_pool, java_pool

 

1)       03:41:30 SQL> show sga

2)        

3)       Total System Global Area  285212672 bytes

4)       Fixed Size                  1218992 bytes

5)       Variable Size              71304784 bytes

6)       Database Buffers          209715200 bytes

7)       Redo Buffers                2973696 bytes

8)       04:45:40 SQL>

9)        

04:46:18 SQL> select name,bytes/(1024*1024) ,resizeable from v$sgainfo;

10)    

11)   NAME                             BYTES/(1024*1024) RES

12)   -------------------------------- ----------------- ---

13)   Fixed SGA Size                          1.16252136 No

14)   Redo Buffers                             2.8359375 No

15)   Buffer Cache Size                              200 Yes

16)   Shared Pool Size                                60 Yes

17)   Large Pool Size                                  4 Yes

18)   Java Pool Size                                   4 Yes

19)   Streams Pool Size                                0 Yes

20)   Granule Size                                     4 No     ;区组大小为4M

21)   Maximum SGA Size                               272 No

22)   Startup overhead in Shared Pool                 36 No

23)   Free SGA Memory Available                        0

24)    

04:49:34 SQL> select sum(bytes)/(1024*1024) size_in_mb  from v$sgastat;

25)    

26)   SIZE_IN_MB

27)   ----------

28)   276.003071

29)    

30)    

04:48:19 SQL> select * from v$sgastat;

31)    

32)   POOL         NAME                            BYTES

33)   ------------ -------------------------- ----------

34)   shared pool  KKJ WRK LAT                       300

35)   shared pool  kfkhsh_kfdsg                     2052

36)   shared pool  event statistics ptr arra         680

37)   shared pool  KGKP randnum                    40000

38)   large pool   PX msg pool                    206208

39)   large pool   free memory                   3988096

40)   java pool    free memory                   4194304

41)    

42)   602 rows selected.

43)    

04:50:37 SQL> show parameter sga;

44)   

45)   NAME                                 TYPE        VALUE

46)   ------------------------------------ ----------- ------------------------------

47)   lock_sga                             boolean     FALSE

48)   pre_page_sga                         boolean     FALSE

49)   sga_max_size                         big integer 272M

50)   sga_target                           big integer 272M

SGA动态尺寸总计不能超过初始化参数SGA_MAX_SIZE的值。

如果sga_target超过了sga_max_size的大小,在Instance重新启动后,sga_max_size会调整成和sga_target一样大小的值。

如果在初始化参数里这些内存池设置为非零,则系统启动后,这些值将作为该参数对应的最小值运行。如果那个值在系统运行时不够,则Oracle将自动为其添加容量,以帮助其优化操作,直到内存使用达到SGA_TARGET所表明的上限。

[oracle@oraserv ~]$ !sql

sqlplus '/as sysdba';

 

SQL*Plus: Release 10.2.0.1.0 - Production on Sat Mar 19 11:17:30 2011

 

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

 

Connected to an idle instance.

 

11:17:35 SQL> startup

ORACLE instance started.

 

Total System Global Area  419430400 bytes

Fixed Size                  1219784 bytes

Variable Size             289407800 bytes

Database Buffers          125829120 bytes

Redo Buffers                2973696 bytes

Database mounted.

Database opened.

11:18:13 SQL> show parameter sga

 

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

lock_sga                             boolean     FALSE

pre_page_sga                         boolean     FALSE

sga_max_size                         big integer 400M

sga_target                           big integer 300M

11:18:23 SQL> alter system set sga_target=500m ;

alter system set sga_target=500m

*

ERROR at line 1:

ORA-02097: parameter cannot be modified because specified value is invalid

ORA-00823: Specified value of sga_target greater than sga_max_size

 

 

11:18:38 SQL> alter system set sga_target=500m  scope=spfile;

 

System altered.

 

11:18:54 SQL> startup force;

ORACLE instance started.

 

Total System Global Area  524288000 bytes

Fixed Size                  1220360 bytes

Variable Size             176161016 bytes

Database Buffers          343932928 bytes

Redo Buffers                2973696 bytes

Database mounted.

Database opened.

11:19:30 SQL> show parameter sga;

 

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

lock_sga                             boolean     FALSE

pre_page_sga                         boolean     FALSE

sga_max_size                         big integer 500M

sga_target                           big integer 500M

11:19:38 SQL>

 

利用后台进程MMAN进行SGA动态管理

[oracle@oracle ~]$ ps -ef |grep ora_|grep ora_

oracle    8012     1  0 11:12 ?        00:00:00 ora_mman_prod

 

 

share pool:

共享池(Share Pool)用于存放最近执行的SQL语句和数据字典信息。

共享池主要有库高速缓存(Library Cache)和数据字典高速缓存(Dictionary cache)两部分组成

1)库高速缓存(Library Cache

库高速缓存用于存放最近执行的sql语句信息,包括sql语句文本,解析代码值及执行计划。

 假设执行一条sql语句

     -select ename,job from emp where empno=7788;

           如果最近(还没有被lru淘汰)执行过这条语句,他就会直接从cache里面读结果;如果没有执行过,就需要读数据文件,这个过程就比较复杂,效率差距很大。

http://blog.csdn.net/yujin2010good/article/details/7235864

 

这里还有两个概念:

物理i/o和逻辑i/o---------11000

物理i/o:从数据缓冲区找不到所需要的数据,就要从硬盘里面读取。

逻辑i/o:从数据缓冲区能找到所需要的数据,

理论上讲一个数据库性能是否良好,这个逻辑i/o应该占95%以上

 dave哥对命中率有详细的描述

http://blog.csdn.net/tianlesoftware/article/details/4674153

 

2)、数据字典高速缓存区(Dictionary cache

用于存放数据字典的信息,包括表、列定义以及权限信息)

库高速缓存和数据字典高速缓存大小是动态变化的,不是固定的。

     SQL> alter  system   set  share_pool_size=60m;

DB buffer

     数据高速缓存(Database Buffer cache)用于存放最近访问的数据块信息,它由许多小缓冲区(缓冲区大小=数据尺寸)组成

Db_cache_size  定义标准的高速缓存尺寸

Db_nk_cache_size  定义非标准的高速缓存尺寸

Oracle学习笔记(1)-------------Oracle体系结构_第4张图片

 

数据库高速缓存区:

Db_cache_size Default 默认池,所有段都被默认高速缓存到默认池。(采用LRU

Db_keep_cache_size ,确保某些数据块始终被保留到内存中

Db_recycle_cache_size ,数据高速缓存区“回收池”

 

 

 

Redo log buffer

   重做日志缓存区(Redo log buffer),用于记载实例的变化。执行DDLDML语句时,服务器进程首先将事物的变化记载到重做日志缓存区,然后才会修改数据高速缓存。

重做日志缓存区由很多重做记录(Redo record)组成,并且每条重做记录记载了被修改数据块的位置以及变换后的数据

Large pool

Oracle学习笔记(1)-------------Oracle体系结构_第5张图片

   

PGA(Program Global Area)

用于存放服务器进程的数据和控制信息,独立于SGA的一块内存区域。

     当用户连接到Oracle Server时,Oracle server会为每个服务器进程分配相应的PGA.

SGA是所有服务器进程都可共享那个的一块内存区域,而每个服务器进程都具有私有的PGA内存空间。

 客户端在通过sql语句连接database时,必须通过实例Instance来连接和管理数据库。

Connection:客户端进程和服务端进程建立通讯。

Session:当用户经过Oracle server认证后开始建立会话,直到用户退出登录,会话结束

 

2、进程结构

 用户进程

server进程

     当客户端运行应用程序时,会启动形影的应用进程,该进程称为用户进程;

     当连接到Oracle Server 时,Oracle在服务器端会为用户进程派生一个新的进程

后台进程

Oracle学习笔记(1)-------------Oracle体系结构_第6张图片

启动实例时,Oracle不仅会分配SGA,还会启动后台进程。

[oracle@oraserv ~]$ ps -ef |grep ora_
oracle    4694     1  0 01:18 ?        00:00:01 ora_pmon_orcl

oracle    4696     1  0 01:18 ?        00:00:00 ora_psp0_orcl

oracle    4698     1  0 01:18 ?        00:00:00 ora_mman_orcl

oracle    4700     1  0 01:18 ?        00:00:00 ora_dbw0_orcl

oracle    4702     1  0 01:18 ?        00:00:00 ora_lgwr_orcl

oracle    4704     1  0 01:18 ?        00:00:06 ora_ckpt_orcl

oracle    4706     1  0 01:18 ?        00:00:01 ora_smon_orcl

oracle    4708     1  0 01:18 ?        00:00:00 ora_reco_orcl

oracle    4710     1  0 01:18 ?        00:00:02 ora_cjq0_orcl

oracle    4712     1  0 01:18 ?        00:00:01 ora_mmon_orcl

oracle    4714     1  0 01:18 ?        00:00:01 ora_mmnl_orcl

oracle    4716     1  0 01:18 ?        00:00:00 ora_d000_orcl

oracle    4718     1  0 01:18 ?        00:00:00 ora_s000_orcl

oracle    4722     1  0 01:18 ?        00:00:00 ora_arc0_orcl

oracle    4724     1  0 01:18 ?        00:00:00 ora_arc1_orcl

oracle    4728     1  0 01:18 ?        00:00:00 ora_qmnc_orcl

oracle    4741     1  0 01:18 ?        00:00:00 ora_q000_orcl

oracle    4743     1  0 01:18 ?        00:00:00 ora_q001_orcl

oracle    5467     1  0 03:46 ?        00:00:00 ora_j000_orcl

 

[oracle@oraserv ~]$

03:50:01 SQL> select paddr,name,description from v$bgprocess where paddr<>'00';

 

PADDR    NAME  DESCRIPTION

-------- ----- ----------------------------------------------------------------

30E16830 PMON  process cleanup

30E16DE4 PSP0  process spawner 0

30E17398 MMAN  Memory Manager

30E1794C DBW0  db writer process 0

30E1B808 ARC0  Archival Process 0

30E1BDBC ARC1  Archival Process 1

30E1C370 ARC2  Archival Process 2

30E17F00 LGWR  Redo etc.

30E184B4 CKPT  checkpoint

30E18A68 SMON  System Monitor Process

30E1901C RECO  distributed recovery

30E195D0 CJQ0  Job Queue Coordinator

30E1C924 QMNC  AQ Coordinator

30E19B84 MMON  Manageability Monitor Process

30E1A138 MMNL  Manageability Monitor Process 2

 


 DBWN

Oracle学习笔记(1)-------------Oracle体系结构_第7张图片

DBWR,用于将数据高速缓存的脏缓冲区数据写入到数据文件中

Oracle学习笔记(1)-------------Oracle体系结构_第8张图片

 

默认情况下只有一个DBWR0进程,通过db_writer_process 可以定义最多10个DBWR进程(DBWR0-DBWR9).

DBWR工作触发条件:

1、 系统发出检查点(CheckPoint)

如:alter system checkpoint local; 这是手动操作。

2、 脏数据块达到阀值

3、服务器进程不能找到空闲的缓冲区

3、超时

4、 rac ping

3、删除或截断表(表空间的相关操作只写表空间相关的内容)

4、表空间正常脱机(ALTER  TABLE … OFFLINE NORMAL)

5、开始表空间备份(ALTER  TABLESAPCE ...BEGIN  BACKUP )

 

rac ping官方解释:

        Every few seconds, the process in one instance sends messages to each instance. The message is received by PING on the target instance. The time for the round trip is measured and collected.

        rac ping是用ops时的概念了,现在已经不用这个概念了,或许没有这个概念了。

 

Lgwr

Oracle学习笔记(1)-------------Oracle体系结构_第9张图片

LGWR,用于将重做日志缓冲区所记载的全部内容写入到重做日志文件中。

Oracle 总是“先日志后修改”(先记载变化然后修改数据);

DBWR工作之前,LGWR首先将事务变化写入到重做日志。

LGWR工作触发条件:

1、提交事务(commit

2、每隔3秒钟

3、当重做日志信息超过1M

4、重做日志缓冲区超过1/3

5、在DBWR进程将脏缓冲区写入到数据文件前

思考:

checkpoint时会不会导致lgwr写?

 

 

Smon

Oracle学习笔记(1)-------------Oracle体系结构_第10张图片

在例程失败的情况下,SMON做以下的恢复:

Instance recovery

        1REDO,重新应用那些被记载的重做日志,但尚未记载的数据文件的数据。因为所有被提交的事务已经记载到了重做日志,所以可以确保恢复事务数据。(前滚)

        2、打开数据库,在打开数据库时,既包含了被提交的数据,也包含了未被提交的数据(加锁)。

        3Undo,取消未提交的数据。打开数据库之后,Oracle会自动使用Undo段回退未提交的数据。(回滚)

整合空闲空间

临时段

 

 

Pmon

Oracle学习笔记(1)-------------Oracle体系结构_第11张图片

PMON,用于监视服务器进程的执行,并且在服务器进程失败时清除该服务器进程。

用户例程意外终止运行时,PMON可以轮询检测该服务进程,并执行以下操作:

1、回退用户的当前事务

2、释放服务器进程所占用的所有表锁和行锁

3、释放用户所占用的其他资源

 

Checkpoint

Oracle学习笔记(1)-------------Oracle体系结构_第12张图片

 

CKPT,用于发出检查点(CheckPoint),检查点会同步数据库的数据文件和控制文件、重做日志)。

 

当发出检查点时,后台进程CKPT将检查点时刻的SCN(System Change Number)写入到控制文件、和数据文件头部,同时会促使后台进程DBWR将所有的脏缓冲区写入到数据文件中。

 

Oracle学习笔记(1)-------------Oracle体系结构_第13张图片

当发出检查点是,不仅后台进程CKPTDBWR要开始工作,LGWR也会将重做日志缓冲区写入到重做日志,从而确保数据文件、控制文件、重做日志的一致性。

CKPT工作触发条件:

1、日志切换(包括手动:ALTER SYSTEM SWITCH LOGFILE,手动归档应该也可以)

2、关闭实例(shutdown abort除外)

3、手工检查点操作(alter  system  checkpoint

4、热备

5、当运行ALTER TABLESPACE/DATAFILE READ ONLY的时候

6、手动设置fast_start_mttr_target

 

检查点发生后,他会立马做出如下事件:

1、更新数据文件头部

2、更新控制文件

主要是scn,用于恢复,chpt发生的频率越高,恢复的时间越短,频率高了,数据库性能可能有影响;所以设置这个参数的时候要慎重。

 

Arcn

Oracle学习笔记(1)-------------Oracle体系结构_第14张图片

 

ARCH,用于将重做日志的事务变化复制到归档日志中(用于重做日志的备份)

SQL> show parameter archive

 

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

archive_lag_target                   integer     0

log_archive_config                   string

log_archive_dest                     string

log_archive_dest_1                   string      location=/disk1/arch

log_archive_dest_10                  string

log_archive_dest_2                   string

log_archive_dest_3                   string

log_archive_dest_4                   string

log_archive_dest_5                   string

log_archive_dest_6                   string

log_archive_dest_7                   string

log_archive_dest_8                   string

log_archive_dest_9                   string

log_archive_dest_state_1             string      enable

log_archive_dest_state_10            string      enable

log_archive_dest_state_2             string      enable

log_archive_dest_state_3             string      enable

 

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

log_archive_dest_state_4             string      enable

log_archive_dest_state_5             string      enable

log_archive_dest_state_6             string      enable

log_archive_dest_state_7             string      enable

log_archive_dest_state_8             string      enable

log_archive_dest_state_9             string      enable

log_archive_duplex_dest              string

log_archive_format                   string      %s_%t_%r.log

log_archive_local_first              boolean     TRUE

log_archive_max_processes            integer     2

log_archive_min_succeed_dest         integer     1

log_archive_start                    boolean     FALSE

log_archive_trace                    integer     0

remote_archive_enable                string      true

standby_archive_dest                 string      ?/dbs/arch

 

三、 database 结构

 

1、物理结构

Oracle物理结构主要由:数据文件,日志文件,控制文件

当然还有一些其他的文件:参数文件,口令文件,告紧日志文件,归档日志文件等

具体内容后面一一总结

 

2、逻辑结构

Oracle学习笔记(1)-------------Oracle体系结构_第15张图片

Oracle学习笔记(1)-------------Oracle体系结构_第16张图片

1、表空间(tablespace),是数据库的逻辑组成部分。

2、段(Segment),用于存放特定的逻辑对象(表、簇、索引等)的所有数据,它由一个或多个区组成的。

如表段、索引段、临时段、undo段等

3、区(extent),是Oracle进行空间分配的逻辑单元,它由相邻的数据块组成。

4、Oracle 块,数据块,是Oracle 在数据文件上执行I/0的最小单位,其尺寸应该为OS块的整数倍

 

 

处理sql

Oracle学习笔记(1)-------------Oracle体系结构_第17张图片

服务器进程处理select语句包括解析(Parse),执行(Execute),和提取数据(Fetch)三个阶段

Oracle学习笔记(1)-------------Oracle体系结构_第18张图片

处理DML语句:

因为DML语句不会返回数据,所以处理DML语句只包括解析和执行两个阶段

Oracle学习笔记(1)-------------Oracle体系结构_第19张图片

 

处理commit

Oracle学习笔记(1)-------------Oracle体系结构_第20张图片

你可能感兴趣的:(Oracle学习笔记(1)-------------Oracle体系结构)