Oracle事务处理

Posted 奔跑的金鱼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle事务处理相关的知识,希望对你有一定的参考价值。

名词解释

DML:Data Manipulation Language (数据库操纵语言) 例如:DELETE、INSERT、UPDATE、SELECT

DDL:Data Definition Language(数据库定义语言) 例如:CREATE、ALTER、DROP、

DCL: Data Control Language (数据库控制语言) 例如:GRANT、REVOKE、DENY

1.按照组成方式

Oracle数据库的事务可以有以下几种组成方式:

  • 一个或多个DML
  • 一个DCL语句
  • 一个DDL语句

2.事务按照启动方式

  • 显示事务

          Oracle 11g中事务是隐式自动开始的,它不需要用户显示的执行开始事务语句

  • 隐性事务

      打开隐性事务设置开关后,执行下一条SQL语句的时候自动启动一个新事务,并且每关闭一个事务时,下一条SQL语句又自动启动一个新事务,直到关闭了隐性事务的设置开关。

  • 自动提交事务

      此处是SQL Server默认模式。当一条有效的SQL语句执行后,成功了便自动提交,如果失败了,那么将自动回滚并返回错误信息。

改变事务的模式只影响当前数据库连接,不影响其他连接中的事务

Oracle事务结束

当下列事件发生的时候结束:

  • 用户执行了COMMIT语句(提交)
  • 用户执行了ROLLBACK语句(回滚)
  • 用户执行了DDL语句(自动提交)
  • 用户执行了DCL语句(自动提交)
  • 用户正常退出SQL*Plus(自动提交)
  • 用户非正常退出SQL*Plus(自动回滚)
  • 系统奔溃,包括硬件或软件故障(自动回滚)

 

以上是关于Oracle事务处理的主要内容,如果未能解决你的问题,请参考以下文章

关于django出现重复点击,多事务处理

Mybatis事务处理

面试官:小伙子你给我说说MySq|并发事务处理细节

NetCore微服务实现事务一致性masstransit之saga使用

CQRS + 微服务处理事件回滚

oracle临时表