为什么存储过程能自动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的原因
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式