如何在oracle中开启一个事务有这样的命令么?当你进入一个会话时你怎么知道当前所处的是否在一个事务中?

如何在oracle中开启一个事务有这样的命令么?当你进入一个会话时你怎么知道当前所处的是否在一个事务中?,第1张

BeginTrans用于开始一个事物;RollbackTrans用于回滚事务;CommitTrans用于提交所有的事务处理结果,即确认事务的处理

BeginTrans和CommitTrans 用于标记事务的开始和结束,在这两个之间的语句,就是作为事务处理的语句

当然不是了,在Oracle中,只有DML才会开启一个事务。也就是说Insert,Update,Delete这些都会开启一个事务,并且该事务在commit/rollback/ddl命令时会自动结束。

其他的,像查询语句Select(不包含For Update等语句)时,是不会开启一个事务的。

补充:

首先有一点非常抱歉,上次的回答中误将DML写成了DDL,可能这一点儿让你误解了。

“当insert语句后会打开事务,然后再来一个insert语句又会是一个新事物是吗”这种说法是不正确的,第一个Insert没有commit或者rollback的情况下,第二个Insert和第一个是属于同一个事务的。因为Insert不属于commit/rollback/ddl命令,而是属于DML命令。

当第一个Insert结束后,立即执行一个新建表,删除表等命令(DDL命令),则会结束当前事务。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9898194.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存