关于ORACLE 的transactional方式下的shutdown ,做了一下实验,记录之:

正常启动ORACLE之后,开三个连接到ORACLE。

在session2执行
SQL> delete from t1 where rownum=1;

1 row deleted.

在session 3执行
SQL> delete from t2 where rownum=1;

1 row deleted.

在session1执行
SQL> shutdown transactional;

这个session会挂起。

我们在session2执行如下的语句:
SQL> rollback;

Rollback complete.

SQL> delete from t1 where rownum=1;
delete from t1 where rownum=1
            *
ERROR at line 1:
ORA-01089: immediate shutdown in progress - no operations are permitted
SQL> select 1 from dual;

         1
----------
         1

可以看到,事务回滚后,不能开启新的事务了。但是可以进行查询操作

现在我们在session3中回滚事务:
SQL> rollback;

回退已完成。

这个时候在session 1中就会出现:
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL>

结论:以transactional方式关闭数据库,当客户端的事务完成后(commit 或 rollback),客户端就不能再次开始一个新的事务,但是可以进行查询。当所有客户端的事务完成后,服务器就会强制断开所有连接,然后关闭数据库。

另外,在以normal方式关闭数据库时,已有的连接不受任何影响,可以新开始一个事务。只是不允许连接新的用户。只有所有的用户都disconnect后,实例才能关闭。对于一个实际的业务系统来说,几乎是一个“不可能完成的任务”。

Trackback

no comment untill now

Add your comment now