- A+
浅析关闭数据库实例的四种方法

通常来说,对于oracle数据库实例的关闭,都经历了三个环节,那就是:关闭数据库、卸载数据库以及关闭oracle实例。下面赵一八笔记分享下oracle数据库实例的关闭方法,一般有四种方式。
那么是哪四种方式呢?分别是normal、transactional、immediate以及abort,具体的语法格式为:shutdown [norma | transactional | immediate | abort],四种关闭数据库实例的方式也都有区别,下面我们具体讲解。
1.normal方式
normal,表示以正常的方式关闭数据库,也称作正常关闭方式。一般来说,如果对关闭数据库的时间没有限制,那就可以采用这种方式。

这种方式,在oracle执行shutdown命令后,返回的响应信息就是关闭数据库的过程,正常关闭数据库时,oracle实际执行了以下的操作:
阻止任何用户建立新的连接;
等待当前所有正在连接的用户主动断开连接;
当所有的用户断开连接后,将立即关闭数据库。
所以这种方法非常的占用时间,对于大型的数据库来说,很难能够在短时间内实现关闭数据库的目的,采用这种方式,也许关闭一个数据库需要几天时间,也许更长,并不推荐。
2.transactional方式
transactional方式称之为事务关闭方式,它的主要作用就是能够保证所有当前的活动事务都可以被提交,并保证在尽可能短的时间内关闭数据库。

以事务关闭数据库时,oracle一般执行以下操作:
阻止用户新连接和开始新事务;
等待所有活动事务提交之后,再断开用户连接;
当所有的活动事务提交完毕、所有的用户都断开连接后,再关闭数据库。
3.immediate方式
immediate方式,就是立即关闭数据库的方式,这种方式能够在尽可能短的时间内关闭数据库。

使用immediate方式关闭数据库,oracle数据库不但会立即停止中断当前用户的连接,还会强行终止当前的活动事务,将未完成的事务回退,并立即关闭数据库,oracle一般执行以下操作:
阻止用户建立新连接和开始新事务;
将未提交的活动事务回退;
关闭数据库。
4.abort方式
abort方式,称之为终止关闭方式,终止关闭方式具有一定的强制性和破坏性。使用该方式强行中断任何数据库操作,可能会丢失一部分数据信息,影响数据库的完整性,我们应该尽可能的避免此方式。

以立即关闭方式关闭数据库,oracle将执行以下的操作:
- 我的微信号
- 这是我的微信扫一扫
-
- 我的微信公众号
- 我的微信公众号扫一扫
-