四、事务介绍和常见的隔离级别,传播行为
简介:讲解什么是数据库事务,常见的隔离级别和传播行为
一、介绍什么是事务,单机事务,分布式事务处理等
二、讲解场景的隔离级别
Serializable: 最严格,串行处理,消耗资源大
Repeatable Read:保证了一个事务不会修改已经由另外一个事务读取但未提交(回滚)的数据
Read Committed:大多数主流数据库的默认事务等级
Read Uncommitted:保证了读取过程当中不会读取到非法数据。
三、讲解常见的传播行为
PROPAGATION_REQUIRED--支持当前事务,若是当前没有事务,就新建一个事务,最多见的选择。
PROPAGATION_SUPPORTS--支持当前事务,若是当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY--支持当前事务,若是当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW--新建事务,若是当前存在事务,把当前事务挂起, 两个事务之间没有关系,一个异常,一个提交,不会同时回滚
PROPAGATION_NOT_SUPPORTED--以非事务方式执行操做,若是当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER--以非事务方式执行,若是当前存在事务,则抛出异常数据库
事务的场景
对于多数据库的场景。分布式事务
分布式的事务通常用消息队列去解决
二、讲解场景的隔离级别
Serializable: 最严格,串行处理,消耗资源大
Repeatable Read:保证了一个事务不会修改已经由另外一个事务读取但未提交(回滚)的数据
Read Committed:大多数主流数据库的默认事务等级
Read Uncommitted:保证了读取过程当中不会读取到非法数据。分布式
PROPAGATION_REQUIRED--支持当前事务,若是当前没有事务,就新建一个事务,最多见的选择。
PROPAGATION_SUPPORTS--支持当前事务,若是当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY--支持当前事务,若是当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW--新建事务,若是当前存在事务,把当前事务挂起, 两个事务之间没有关系,一个异常,一个提交,不会同时回滚
PROPAGATION_NOT_SUPPORTED--以非事务方式执行操做,若是当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER--以非事务方式执行,若是当前存在事务,则抛出异常
blog