4.事务提交过程,事务基本概念,Oracle中的事务生命周期,保存点savepoint,数据库的隔离级别



  1. 事务提交过程

  1. 事务

基本概念


概念:一个或者多个DML语言组成

特点:要么都成功,要么都失败

事务的隔离性:多个客户端同时操作数据库的时候,要隔离它们的操作,

否则出现:脏读 
不可重复读 
幻读


Oracle默认情况下,事务是打开的


commit案例:

SQL> create table t1(tid int,tname varchar2(20));

表已创建。

SQL> select * from tab;

TNAME                         
TABTYPE  CLUSTERID

------------------------------ ------- ----------

BONUS                         
TABLE

DEPT                          
TABLE

EMP                           
TABLE

EMP10                         
TABLE

SALGRADE                      
TABLE

T1       
                     TABLE

已选择6行。

SQL> insert into t1(tid,tname) values(1,‘aaaaa‘);

已创建 1
行。

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

SQL> commit;

提交完成。

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

SQL> rollback;

回退已完成。

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

SQL>



rollback案例:

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

SQL> insert into t1(tid,tname) values(2,‘bbb‘);

已创建 1
行。

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

2 bbb

SQL> rollback;

回退已完成。

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

SQL>

  1. Oracle中的事务生命周期

1.事务的起始标志 DML语言(oracle默认事务是打开的)


2.事务的结束标志


提交


显式提交commit


隐式提交


执行DDL语句

Eg:执行create table的时候还有1个隐式的功能

提交之前没有提交的DML语句(insert
update)


正常退出


回滚


显式rollback


隐式:掉电/宕机/非正常退出,这几者等价于系统出错了

4
保存点savepoint


案例:


SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

SQL> insert into t1(tid,tname) values(2,‘bbb‘);

已创建 1
行。

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

2 bbb

SQL> rollback;

回退已完成。

SQL> select * from t1;

TID TNAME

---------- --------------------

1 aaaaa

SQL>



总结:最后一条insert语句没有插入进去,回滚到了指定的保存点

  1. 数据库的隔离级别

对于同时运行的多个事务,当这些事务访问数据库中相同的数据时,如果没有采取必要的隔离机制,就会导致各种并发问题


脏读:对于两个事务T1,T2,T1读取了已经被T2更新但还没有被提交的字段之后,若T2回滚。T1读取的内容就是临时且无效的。


不可重复读:对于两个事物T1,T2,T1读取了一个字段,然后T2更新了该字段,之后T1再次读取同一个字段,值就不同了。


幻读:对于两个事务T1,T2,T1从一个表中读取了一个字段,然后T2在该表中插入了一些新的行。之后,如果T1再次读取同一个表,就会多出几行。


数据库事务的隔离性:数据库系统必须具有隔离并发运行多个事务的能力,使它们不会相互影响,避免各种并发问题。


一个事务与其他事务隔离的程度称为隔离级别.
数据库规定了多种事务隔离级别,
不同隔离级别对应不同的干扰程度,
隔离级别越高,
数据一致性就越好,
但并发性越弱


数据库提供4中事务隔离级别:sql99



Oracle
支持的
2 种事务隔离级别:READ COMMITED, SERIALIZABLE. Oracle
默认的事务隔离级别为: READ COMMITED

另外还支持一种隔离级别:read-only


Mysql
支持
4 中事务隔离级别. Mysql
默认的事务隔离级别为: REPEATABLE READ

时间: 10-10

4.事务提交过程,事务基本概念,Oracle中的事务生命周期,保存点savepoint,数据库的隔离级别的相关文章

检查Oracle 中死事务的语句

SQL> SELECT KTUXEUSN, KTUXESLT, KTUXESQN, /* Transaction ID */ 2 KTUXESTA Status, KTUXECFL Flags ,KTUXESIZ 3 FROM x$ktuxe 4 WHERE ktuxesta!='INACTIVE'; KTUXEUSN KTUXESLT KTUXESQN STATUS FLAGS KTUXESIZ ---------- ---------- ---------- ----------------

mysql 事务提交过程

打开binlog选项后,执行事务提交命令时,就会进入两阶段提交模式.两阶段提交分为prepare阶段和commit两个阶段.流程如下 :这里面涉及到两个重要的参数:innodb_flush_log_at_trx_commit和sync_binlog,参数可以设置不同的值,具体可以查看mysql的帮助手册.我这里设置的是双一模式(innodb_flush_log_at_trx_commit=1,sync_binlog=1),不同的模式区别在于,写文件调用write和落盘fsync调用的频率不同,所

oracle中的事务

数据库事务有严格的定义,它必须满足4个特性:原子性(Atomic):表示组成一个事务的多个数据库操作是一个不可分割的原子单元只有所有的操作执行成功,整个事务才能提交,事务中任何一个数据库操作失败,己经执行的任何操作都必须撤销,让数据主加返回到初状态.一致性(Consistency):事务操作成功后,数据所处的状态和它的业务规则是一致的,即数据不会被被破坏.如从A账户转账100元到B账户,不管操作成功与否,A和B的存款总额不变的.隔离性(Isolation):在并发数据操作时,不同的事务拥有各自的

【Oracle】浅析Oracle中的事务

1. 什么是事务 在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个工作单元操作,要么一个也不执行. 如:网上转帐就是典型的要用事务来处理,用以保证数据的一致性. 2. 事务特性 SQL92标准定义了数据库事务的四个特点: 原子性(Atomicity):一个事务里面所有包含的SQL语句是一个执行整体,不可分割,要么都做,要么都不做. 一致性(Consistency):事务开始时,数据库中的数

Oracle 浅析Oracle中的事务

1. 什么是事务 在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个工作单元操作,要么一个也不执行. 如:网上转帐就是典型的要用事务来处理,用以保证数据的一致性. 2. 事务特性 SQL92标准定义了数据库事务的四个特点: 原子性(Atomicity):一个事务里面所有包含的SQL语句是一个执行整体,不可分割,要么都做,要么都不做. 一致性(Consistency):事务开始时,数据库中的数

事务的特性及事务的隔离级别(转)

原文:http://www.cnblogs.com/fjdingsd/p/5273008.html 本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,这和前面两篇博客介绍事务的功能是一样的概念,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响. ⑵ 一致性(Consi

《高性能MySQL》读书笔记--锁、事务、隔离级别 转

1.锁 为什么需要锁?因为数据库要解决并发控制问题.在同一时刻,可能会有多个客户端对表中同一行记录进行操作,比如有的在读取该行数据,其他的尝试去删除它.为了保证数据的一致性,数据库就要对这种并发操作进行控制,因此就有了锁的概念. 1.1锁的分类 从对数据操作的类型(读\写)分 读锁(共享锁):针对同一块数据,多个读操作可以同时进行而不会互相影响. 写锁(排他锁):当前写操作没有完成前,它会阻断其他写锁和读锁. 大多数时候,MySQL锁的内部管理都是透明的. 1.2锁粒度(Lock granula

《高性能MySQL》读书笔记--锁、事务、隔离级别

1.锁 为什么需要锁?因为数据库要解决并发控制问题.在同一时刻,可能会有多个客户端对表中同一行记录进行操作,比如有的在读取该行数据,其他的尝试去删除它.为了保证数据的一致性,数据库就要对这种并发操作进行控制,因此就有了锁的概念. 1.1锁的分类 从对数据操作的类型(读\写)分 读锁(共享锁):针对同一块数据,多个读操作可以同时进行而不会互相影响. 写锁(排他锁):当前写操作没有完成前,它会阻断其他写锁和读锁. 大多数时候,MySQL锁的内部管理都是透明的. 1.2锁粒度(Lock granula

【mysql】关于事务的隔离级别

一.锁的种类 MySQL中锁的种类很多,有常见的表锁和行锁,也有新加入的Metadata Lock等等,表锁是对一整张表加锁,虽然可分为读锁和写锁,但毕竟是锁住整张表,会导致并发能力下降,一般是做ddl处理时使用. 行锁则是锁住数据行,这种加锁方法比较复杂,但是由于只锁住有限的数据,对于其它数据不加限制,所以并发能力强,MySQL一般都是用行锁来处理并发事务 二.锁粒度 为了尽可能提高数据库的并发度,每次锁定的数据范围越小越好,理论上每次只锁定当前操作的数据的方案会得到最大的并发度,但是管理锁是