💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
关闭数据库与实例 与数据库启动一下,关闭数据库与实例也分为3步:关闭数据库-->实例卸载数据库--->终止实例。 (1)关闭数据库,oracle将重做日志高速缓存中的内容写入重做日志文件,并且将数据库高速缓存中被改动过的数据写入数据文件,然后再关闭所有的数据文件和重做日志文件,这时数据库的控制文件仍然处于打开状态,但是由于数据库处于关闭状态,所以用户无法访问数据库。 (2)卸载数据库,关闭数据库后,例程才能被卸载,控制文件再这个时候被关闭,但例程仍然存在 。 (3)终止例程,进程终止,分配给例程的内存sga区被回收。 1.Nomal(正常关闭方式) 命令:shutdown nomal 讲解:正常方式关闭数据时,Oracle执行如下操作: (1)阻止任何用户建立新的连接。 (2)等待当前所有正在连接的用户主动断开连接(此方式下Oracle不会立即断掉当前用户的连接,这些用户仍然操作相关的操作) (3)一旦所有的用户都断开连接,则立即关闭、卸载数据库,并终止实例。(所以,一般以正常方式关闭数据库时,应该通知所有在线的用户尽快断开连接) 2.Immediate(立即关闭方式) 命令:shutdown immediate 讲解: (1)阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务。 (2)Oracle不等待在线用户主动断开连接,强制终止用户的当前事务,将任何未提交的事务回退。(如果存在太多未提交的事务,此方式将会耗费很长时间终止和回退事务) (3)直接关闭、卸载数据库,并终止实例。 3.Transactional(事务关闭方式) 命令:shutdown transactional 讲解:这种方式介于正常关闭方式跟立即关闭方式之间,响应时间会比较快,处理也将比较得当。执行过程如下: (1)阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务。 (2)等待所有未提交的活动事务提交完毕,然后立即断开用户的连接。 (3)直接关闭、卸载数据库,并终止实例。 4.Abort(终止关闭方式) 命令:shutdown abort 讲解:这是比较粗暴的一种关闭方式,当前面3种方式都无法关闭时,可以尝试使用终止方式来关闭数据库。但是以这种方式关闭数据库将会丢失一部份数据信息,当重新启动实例并打开数据库时,后台进程SMON会执行实例恢复操作。一般情况下,应当尽量避免使用这种方式来关闭数据库。执行过程如下: (1)阻止任何用户建立新的连接,同时阻止当前连接的用户开始任何新的事务。 (2)立即终止当前正在执行的SQL语句。 (3)任何未提交的事务均不被退名。 (4)直接断开所有用户的连接,关闭、卸载数据库,并终止实例。