为什么存储过程能自动rollback,但不能自动commit
若以下回答无法解决问题,邀请你更新回答
2016-07-20
展开全部
在ORACLE中,当执行DDL语句时总是需要申请一个DDL锁,以保证DDL语句执行期间,所操作对象不会被其他SESSION修改。譬如,当执行语句ALTER TABLE T时,表T将会获得一个排它的DDL锁,语句执行结束,该锁被立即释放。事实上在ORACLE中,这是通过在DDL语句前后加上隐式的COMMIT/ROLLBACK语句来实现的。
因此,无论执行成功与否,DDL语句总是要提交的。需要注意的是,DDL语句开始执行之前是先提交的。因此,即使DDL语句执行失败,也不会ROLLBACK掉之前的事务。
回到最初的问题。在ORACLE中,一个存储过程块被当作一个语句,如果其中使用了DDL语句,那么如果后续的执行失败,也无法ROLLBACK掉整个事务,这样无疑违反了事务的原子性。
前面是复制来的,我自己的理解:关系数据库是应对事务的数据库,在处理同一个事务的同时不可以处理其他的事务,这就是为什么不能在存储过程中使用DDL的原因
因此,无论执行成功与否,DDL语句总是要提交的。需要注意的是,DDL语句开始执行之前是先提交的。因此,即使DDL语句执行失败,也不会ROLLBACK掉之前的事务。
回到最初的问题。在ORACLE中,一个存储过程块被当作一个语句,如果其中使用了DDL语句,那么如果后续的执行失败,也无法ROLLBACK掉整个事务,这样无疑违反了事务的原子性。
前面是复制来的,我自己的理解:关系数据库是应对事务的数据库,在处理同一个事务的同时不可以处理其他的事务,这就是为什么不能在存储过程中使用DDL的原因
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询