(本文章为编者在学习中收集总结的笔记,仅供学习,如有侵权,请联系我)
事务——Transation
事务是什么?
事务指逻辑上的一组操作,这组操作要么全部成功,要么全部失败.
事物的特性:
1.原子性Atomic:事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生.
2.一致性Consistent:事务处理前后数据的完整性必须保持一致.
3.隔离性Isolated:多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要相互隔离.
4.持久性Durable:一个事务一旦被提交,它对数据库中数据的改变就是永久性的,即使数据库发生故障也不应该对其有任何影响.
Spring事务管理接口:
PlatformTransactionManager:事务管理器
TransactionDefinition:事务定义信息(事务隔离级别、传播行为)
TransactionStatus:事务具体运行状态
(1)Mysql 默认采用的 REPEATABLE_READ隔离级别
(2)Oracle 默认采用的 READ_COMMITTED隔离级别
如果不考虑隔离性,会引发如下的安全问题:
1.脏读。 一个事务读取了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据是无效的。
2.不可重复读。 在同一个事务中,多次读取同一数据返回的结果有所不同。
3.幻读。 一个事务读取了几行记录后,另一个事务插入一些记录,幻读就发生了。再后来的查询中,第一个事务就会发现有些原来没有的记录。