mysql数据库的事务隔离级别有哪些
Mysql数据库的事务隔离级别有以下几种:1. 读未提交(Read Uncommitted):允许一个事务读取到其他事务未提交的数据,存在脏读的风险。
2. 读已提交(Read Committed):保证一个事务只能读取到已经提交的数据,避免了脏读,但仍可能出现不可重复读和幻读的问题。
3. 可重复读(Repeatable Read):保证在同一个事务中多次读取同样的数据时,结果都是一致的,避免了脏读和不可重复读,但仍可能出现幻读的问题。
4. 串行化(Serializable):最高的事务隔离级别,强制事务串行执行,避免了脏读、不可重复读和幻读的问题,但并发性能较低。
需要注意的是,不同的隔离级别在保证数据一致性的同时也增加了事务的开销和并发性能的影响。
具体选择哪个隔离级别,需要根据应用场景的读写要求和并发操作的需求综合考虑。
my sql四个级别
Read Uncommitted(读取未提交内容)
在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少。读取未提交的数据,也被称之为脏读(Dirty Read)。
Read Committed(读取提交内容)
这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)。它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变。这种隔离级别 也支持所谓的不可重复读(Nonrepeatable Read),因为同一事务的其他实例在该实例处理其间可能会有新的commit,所以同一select可能返回不同结果。
Repeatable Read(可重读)
这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。简单的说,幻读指当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行。InnoDB和Falcon存储引擎通过多版本并发控制(MVCC,Multiversion Concurrency Control)机制解决了该问题。
Serializable(可串行化)
这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。简言之,它是在每个读的数据行上加上共享锁。在这个级别,可能导致大量的超时现象和锁竞争。
下述哪个是spring的默认事务隔离策略
Spring默认的事物隔离策略有以下几种
1:DEFAULT
DEFAULT 这是spring默认的隔离级别,表示使用数据库默认的事务隔离级别。另外四个与JDBC的隔离级别相对应。
2:READ_UNCOMMITTED
READ_UNCOMMITTED 这是事务最低的隔离级别,它充许别外一个事务可以看到这个事务未提交的数据。这种隔离级别会产生脏读,不可重复读和幻读。
3:READ_COMMITTED
这是Sql Server , Oracle默认隔离级别
READ_COMMITTED 保证一个事务修改的数据提交后才能被另外一个事务读取。这种事务隔离级别可以避免脏读出现,但是可能会出现不可重复读和幻读。
4:REPEATABLE_READ
这是MySQL-InnoDB默认隔离级别
REPEATABLE_READ这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻读。
5:SERIALIZABLE
SERIALIZABLE 事务被处理为顺序执行。防止脏读,不可重复读,防止幻读。