ORACLE实例与数据库详解

来源:互联网 发布:淘宝的淘抢购不见了? 编辑:程序博客网 时间:2024/05/29 03:30

ORACLE实例与数据库详解

 

在实际的开发应用中,关于Oracle数据库,经常听见有人说建立一个数据库,建立一个Instance,启动一个Instance之类的话。 其实问他们什么是数据库,什么是Instance,很可能他们给的答案就是数据库就是 InstanceInstance就是数据库啊,没有什么区别。在这里,只能说虽然他们Oracle用了可能有了一定的经验,不过基础的概念还是不太清楚。

 

什么是数据库,其实很简单,数据库就是存储数据的一种媒介。比如常用的文件就是一种,在Oracle10G中,数据的存储有好几种。第一种是文件形式,也就是在你的磁盘中创建一批文件,然后在这些文件中存储信息。第二种就是磁盘阵列形式,这个是什么意思呢,这个就是说明数据库不是存放为某个文件,而是把一个或者多个磁盘格式化成Oracle的一种格式了,等于整个磁盘就是存放Oracle数据库的,不能作为别的用途。这样的优点是存储性能高,因为不再借助别的文件格式了,而是把整个磁盘都成为Oracle最适应的文件系统格式。当然还可能有别的形式,比如网络什么的。不过我们最常用的还是文件格式的,在文件格式中,数据库指的就是那些数据文件,控制文件以及REDO文件等等一系列文件。

 

什么是InstanceInstance其实就是指的操作系统中一系列的进程以及为这些进程所分配的内存块。在Oracle中,我们可以新建一个OracleInstance,这个时候虽然有了进程还有SGA等一系列的内存快,但是这个时候并没有把数据库文件读取进来。所以只是一个实例,在后来,你可以通过命令手动或者自动地把数据库文件加载进我们的数据库Instance中,这个时候的数据库才可以让我们真正的开始访问操作。所以说,数据库的应用如果想实现,数据库和数据库Instance是缺一不可的,如果只有数据库的那些文件,那么,只能代表数据在这个文件中,但是我们无法直接进行操作。而如果只有数据库Instance,那么我们虽然可以急性操作,但是也不知道操作哪些数据,操作生成的数据也无法保存等等。所以,当一个Oracle Instance真正Load了一个Oracle Database了以后,数据库才可以被我们使用。在这里要注意一点的是,Oracle的实例在启动以后,只能load一次数据库,如果想把数据库与Instance断开,然后再重新挂在一个数据库Instance,那么就需要你首先把数据库Instance进程结束,然后重新建立这个instance的一个进程,再load另外一个数据库。否则肯定要抛除ORA-16169错误,说数据库已经被打开。因为一个数据库Instance在其生存期中最多只能load和打开一个instanceORACLE实例 = 进程 + 进程所使用的内存(SGA)  实例是一个临时性的东西,你也可以认为它代表了数据库某一时刻的状态!数据库 = 重做文件 + 控制文件 + 数据文件 + 临时文件数据库是永久的,是一个文件的集合。ORACLE实例和数据库之间的关系

 

1. 临时性和永久性

2. 实例可以在没有数据文件的情况下单独启动 startup nomount , 通常没什么意义

3. 一个实例在其生存期内只能装载(alter database mount)和打开(alter database open)一个数据库

4. 一个数据库可被许多实例同时装载和打开(RAC)RAC环境中实例的作用能够得到充分的体现!

 

 

[ORACLE实例与数据库启动方式]:

1AIX5.3oracle用户登陆。

2、登陆sqlplus

$sqlplus /nolog

3、链接数据库实例hrbhouse

SQL> conn sys/vhfs@hrbhouse

 

as sysdba

Connected to an idle instance.

#查看状态

SQL> show instance

instance "local"

SQL> show sga

ORA-01034: ORACLE not available

#数据库为启动

4、启动实例hrbhouse下的数据库。

SQL> startup

ORACLE instance started.

Total System Global Area  935329792 bytes

Fixed Size                  2025304 bytes

Variable Size             247466152 bytes

Database Buffers          683671552 bytes

Redo Buffers                2166784 bytes

Database mounted.

Database opened.

 

#停止实例hrbhouse下的数据库

SQL> shutdown

Database closed.

Database dismounted.

ORACLE instance shut down.