四大特征
- 原子性,要么同时成功,要么同时失败,是不可分割的最小单位
- 持久性,提交或回滚数据库会持久化保存数据
- 隔离性,多个事务之间,相互独立,由锁来实现
- 一致性,数据操作前后,总量保持不变。数据库从一个一致状态变换到另外一个一致性状态
事务有关命令
set autocommit=0
开启:start transation
回滚:rollback
提交:commit
Set @@commit 查询
Set @@commit 0代表手动提交,1代表自动提交
select @@tx_isolation查询隔离级别
Set global transaction isolation level 级别 设置
隔离级别
隔离级别
read uncommitted
read committed oracle默认
repeatable read mysql默认 解决不了幻读
serializable
隔离级别解决的对应问题
- 丢失更新:两个事务同时修改一个值,后面的事务会覆盖前一个事务的更新动作。
解决:对行加锁,只允许并发一个更新事务。
- 脏读:一个事务读到另一个事务中已修改但没有提交的数据,若另一个事务执行了撤销动作,则得到了脏数据。
解决:其他事务不能读取未完成事务中修改的值
- 不可重复读:同一个事务中,两次读取到的数据不一样。事务1修改数据,提交之前事务2先读取了数据,事务1提交之后事务2又读取了该数据结果两次读取的数据不一样
解决:修改事务完全提交之后才可以读取数据
- 幻读:事务1更新新增1条数据正好满足事务2的查询条件,而事务2重新查询相同的条件会多出一条记录
解决:其他事务在操作事务完成数据处理之前不可以添加新数据
传播行为
-
TransactionDefinition.PROPAGATION_REQUIRED:
如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。这是默认值。 -
TransactionDefinition.PROPAGATION_REQUIRES_NEW:
创建一个新的事务,如果当前存在事务,则把当前事务挂起。 -
TransactionDefinition.PROPAGATION_SUPPORTS:
如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。 -
TransactionDefinition.PROPAGATION_NOT_SUPPORTED:
以非事务方式运行,如果当前存在事务,则把当前事务挂起。 -
TransactionDefinition.PROPAGATION_NEVER:
以非事务方式运行,如果当前存在事务,则抛出异常。 -
TransactionDefinition.PROPAGATION_MANDATORY:
如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。 -
TransactionDefinition.PROPAGATION_NESTED:
如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行;
如果当前没有事务,则该取值等价于TransactionDefinition.PROPAGATION_REQUIRED。