事务:由一系列操作组成的一个逻辑工作单元
如,向账户中存入100元就是一个事务
事务类型:
1.自动提交,即执行完update马上保存数据
2.手动提交,执行update不保存数据,先放入
缓存,只有执行commit,才保存数据
java代码:
conn.setAutoCommit(false);//设置手动提交,sql执行放入缓存
conn.commit(); //手动提交,清空缓存,刷入数据库保存
conn.rollback(); //回滚,清空缓存
---------------------------------------
事务的ACID属性:
原子性(Atomicity) :
事务是一个不可分割的工作单位,
事务中的操作要么都发生,要么都不发生。
一致性(Consistency) :
事务必须使数据库从一个一致性状态变换到另外一个一致性状态。
(数据不被破坏)
隔离性(Isolation):
事务的隔离性是指一个事务的执行不能被其他事务干扰,
即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,
并发执行的各个事务之间不能互相干扰。
持久性(Durability):
持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,
接下来的其他操作和数据库故障不应该对其有任何影响
-------------------------------------
隔离的四个级别:对事物并发控制的四个等级。
-串行化(序列化)(serializable)
事务串行访问,不能并发访问
所以不可能导致脏读、幻读、不可重复读
-可重复读(repeatable read)
不可能产生脏读、不可重复读,
可能产生幻读。
-读已提交(read committed)
事务过程中不可能产生脏读了
但可能产生不可重复读、幻读
-读未提交(read uncommitted)
能查到其他事务未提交的数据,可能导致脏、幻、不可重复读
-------------------------------------------------
*脏读(dirty read):当一个事务正在访问数据,并且对数据进行了修改,
而这种修改还没有提交到数据库中,这时,
另外一个事务也访问这个数据,然后使用了这个修改后的数据。
即,读到未提交的数据。
*幻读(phantom read):当第一个事务进行查询后,第二个事务对此数据执行了一个操作,
当第二个事务未提交时,第一个事务的查询结果跟原来一样,即不会
导致脏读。当第二个事务提交后,第一个事务的查询结果还是
一样的,即不会导致不可重复读。
当第一个事务对数据进行一次操作后,执行后的结果是建立在
第二个事务操作后的,查询的结果是不可思议的,即幻读。
*不可重复读(non-repeatable read):是指在一个事务内,多次读同一数据,
在这个事务还没有结束时,另外一个事务也访问该同一数据。
那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,
那么第一个事务两次读到的的数据可能是不一样的。
-------------------------------------------------------
隔离级别 | 脏读(Dirty Read) | 不可重复读(NonRepeatable Read) | 幻读(Phantom Read) |
读未提交(Read uncommitted) | 可能 | 可能 | 可能 |
读已提交(Read committed) | 不可能 | 可能 | 可能 |
可重复读(Repeatable read) | 不可能 | 不可能 | 可能 |
串行化(Serializable ) | 不可能 | 不可能 | 不可能 |
-----------------------------------------------------------------
1、mysql默认的隔离级别为Repeatable_Read
2、sqlserver 默认的隔离级别为Read Commited
3、oracle数据库支持READ COMMITTED和SERIALIZABLE两种事务隔离性级别,
不支持READ UNCOMMITTED和REPEATABLE READ这两种隔离性级别,
oracle数据库默认使用的事务隔离性级别却是READ COMMITTED.
--------------------------------------------------------
隔离操作的sql语句:
查看提交模式
select @@autocommit;
0:表示手动提交
1:自动提交
begin //开始一个事务
rollback //事务回滚
commit //提交事务
*当set autocommit =0 后,所有的SQL都将做为事务处理,直
到commit确认或rollback结束。
*注意:当你结束这个事务的同时也开启了个新的事务
查询当前事务的隔离级别
select @@tx_isolation
设置当前连接的隔离级别
SET TRANSACTION ISOLATION LEVEL 隔离级别
设置数据库系统的全局的隔离级别
SET global TRANSACTION ISOLATION LEVEL 隔离级别
相关推荐
查询:默认事务隔离级别 mysql> select @@tx_isolation;当前会话的默认事务隔离级别 mysql> select @@session.tx_isolation;当前会话的默认事务隔离级别 mysql> select @@global.tx_isolation;全局的事务隔离级别
MySQL事务隔离级别是数据库管理系统中一个非常重要的概念,它关系到数据的一致性和并发性能。在MySQL中,事务被用于确保数据库操作的原子性、一致性、隔离性和持久性(ACID特性)。事务隔离级别主要涉及四个方面:读...
MySQL数据库管理系统提供了四种事务隔离级别来处理事务并发中可能遇到的问题。事务并发问题通常包括脏读、不可重复读和幻读。 一、事务的基本要素(ACID) 事务具有四个基本要素,即原子性(Atomicity)、一致性...
Spring 框架提供了一套完善的事务管理机制,其中包含了多种事务传播属性和事务隔离级别。这些特性使得在处理数据库操作时,能够更好地控制事务的边界和行为,从而确保数据的一致性和完整性。 首先,我们来看一下...
### Spring 事务传播特性和事务隔离级别详解 #### 一、Spring 事务传播特性 在进行多层服务架构设计时,事务的管理尤其重要。为了确保数据的一致性,Spring 提供了一种灵活的方式来控制事务的传播行为。下面详细...
SQL Server的锁机制和事务隔离级别是数据库管理系统中确保数据一致性、避免并发问题的重要机制。在SQL Server中,锁主要用于控制多个用户同时访问同一数据时的并发操作,而事务隔离级别则是确定在事务中如何处理这些...
深入理解Mysql事务隔离级别与锁机制 Mysql事务隔离级别与锁机制是数据库系统中非常重要的概念,它们都是为了解决多事务并发问题而设计的。下面我们将深入讲解这些机制,让大家彻底理解数据库内部的执行原理。 事务...
事务传播特性&事务隔离级别 事务传播特性是指在 Java 中,事务的传播行为,即在多个事务之间如何交互和传播。Java 中有七种事务传播特性,分别是: 1. PROPAGATION_REQUIRED:如果存在一个事务,则支持当前事务。...
事务隔离级别 课程目标 了解 —— 事务隔离级别的概念; 理解 —— 事务隔离的四种级别; 掌握 —— 事务隔离级别的设置; 事务隔离级别 事务隔离:每一个事务都有一个所谓的隔离级,它定义了用户彼此之间隔离和交互...
介绍数据库事务的四种隔离级别,比较不同隔离级别的区别和影响
在多用户并发访问数据库系统时,事务隔离级别的设置对于保障数据一致性与系统并发性能之间至关重要。本文档详细探讨了SQL Server中不同事务隔离级别的实验研究,揭示了各隔离级别与锁管理之间的关系,并通过实验验证...
### Spring事务的传播特性和事务隔离级别 #### 一、Spring事务的传播特性(Propagation) 在Spring框架中,事务管理不仅提供了ACID属性的支持,还引入了事务的传播特性,这些特性决定了当一个方法调用另一个方法时,...
**事务隔离级别** 在计算机科学,尤其是数据库管理系统(DBMS)的设计中,事务隔离级别是确保数据一致性、避免并发操作导致的问题的关键概念。事务是一系列数据库操作的逻辑单元,它们要么全部成功,要么全部失败。...
### 数据库事务隔离级别详解 #### 一、引言 在多用户共享的数据库系统中,为了保证数据的一致性和准确性,必须对并发事务进行控制。数据库事务隔离级别是用来管理多个事务之间相互影响的程度,主要解决的问题包括脏...
【事务隔离级别】 在计算机科学,特别是在数据库管理系统(DBMS)中,事务隔离级别是确保数据库并发操作一致性的重要概念。事务是一系列数据库操作的逻辑单元,必须作为一个整体执行,要么全部成功,要么全部失败。...
Hibernate 事务隔离级别 深入探究 在 Hibernate 中,事务隔离级别是指数据库系统提供的一种机制,以解决并发事务带来的问题。为了确保数据库的可靠性和一致性,Hibernate 提供了四种事务隔离级别,分别是 ...
理解SQL Server中事务隔离级别及相应封锁机制 SQL Server中事务隔离级别是数据库管理系统中一个重要的概念,它决定了事务之间的并发执行和数据的一致性。本文将详细介绍SQL Server中事务隔离级别的概念、分类、特点...
MySQL 支持四种事务隔离级别:READ UNCOMMITTED(读未提交)、READ COMMITTED(读已提交)、REPEATABLE READ(可重复读)和 SERIALIZABLE(串行化)。每种隔离级别对应不同程度的事务并发问题的防范,其中,MySQL ...