每个用户使用数据库,必须先启动数据库。每个启动的数据库就是对应一个实例,实例可以理解为数据库运行时在内存里部分。
数据库启动分三步走:
1 启动实例: (此时启动的数据库实例还没有跟任何数据库进行关联。换句话说,即使数据库不存在也可以启动例程。启动例程主要是跟初始化参数有关,主要是用来初始化数据库的运行环境。)
数据库在关闭的情况下启动实例的操作是Startup nomount
关闭数据库的操作时:shutdown immediate
2 装载数据库: (主要完成以下工作:将数据库与一个已打开的实例关联起来,
打开初始化参数文件中指定的控制文件
根据控制文件获得数据文件和重做日志文件的名称和状态,并进行装载
此时数据库仍然是出于关闭状态的。用户无法与数据库建立连接,无法访问数据库并对数据库进行更改。显然,如果只是装载数据库而没有打开数据库的话,对于普通用户来说是没有多大作用的。但是对于数据库管理员来说此时他发展的舞台就很大了。因为只装载数据库而没有打开它,数据库管理员已经可以通过命令来维护数据库)
在例程启动的状态下的操作: alter database mount;
在例程关闭的状态下的操作:startup mount
3 打开数据库: (程序能够访问后台数据库系统。用户才能够查询、更改数据库中的记录。
在数据库处于装载mount的状态下:alter database open
在数据库处于关闭的状态下:startup 或 startup open)
来源:oschina
链接:https://my.oschina.net/u/2004245/blog/356544