-
如果不考虑隔离性,会引发如下的安全问题: 1.脏读。 一个事务读取了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据是无效的。 2.不可重复读。 在同一个事务中,多次读取同一数据返回的结果有所不同。 3.幻读。 一个事务读取了几行记录后,另一个事务插入一些记录,幻读就发生了。再后来的查询中,第一个事务就会发现有些原来没有的记录。
查看全部 -
Spring事务管理高层抽象主要包括三个接口: PlatformTransactionManager:事务管理器 TransactionDefinition:事务定义信息(事务隔离级别、传播行为,超时,只读) TransactionStatus:事务具体运行状态
查看全部 -
什么是事务?<br> 事务指逻辑上的一组操作,这组操作要么全部成功,要么全部失败.<br> 事物的特性:<br> 1.原子性Atomic:事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生.<br> 2.一致性Consistent:事务处理前后数据的完整性必须保持一致.<br> 3.隔离性Isolated:多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要相互隔离.<br> 4.持久性Durable:一个事务一旦被提交,它对数据库中数据的改变就是永久性的,即使数据库发生故障也不应该对其有任何影响.
查看全部 -
四大特性:原子性、一致性、隔离性、持久性。
查看全部 -
Spring事务管理总结
查看全部 -
事务传播行为
查看全部 -
事物隔离级别
查看全部 -
serializble 事物是排队的确保不发生脏读、幻都、不可重复读
查看全部 -
propagation_requires_new aaa事务挂起,bbb和aaa不在一个事务中
查看全部 -
spring事务隔离级别
DEFAULT:使用后端数据库默认的隔离级别(spring中的选择项)
READ_UNCOMMITED:允许读还未提交的改变了的数据,可能导致脏、幻、不可重复读。
READ_COMMITTED:允许在并发事务已经提交后读取。可以防止脏读,但幻读和不可重复读仍可发生
REPEATABLE_READ:对相同字段的多次读取是一致的,除非数据被事务本身改变。可防止脏、不可能重复读,但是幻读仍可能发生。
SERIALIZABLE:完全服从ACID的隔离级别,确保不发生脏、幻、不可重复读。这在所有的隔离级别中是最慢的。它是典型的通过完全锁定在事务中涉及的数据表来完成的。
查看全部 -
事务三个接口:
platformTransactionManageer
TransactionDefinition
TransactionStatus
查看全部 -
事物的持久性
查看全部 -
事物的隔离性
查看全部 -
事物的一致性
查看全部 -
原子性概念
查看全部
举报