1.定义:
事务是由一个或多个SQL语句,结合在一起所形成的一个逻辑处理单元,这些SQL语句要么完全执行,要么完全不执行 ,它是一个不可分割的工作执行单元。
2.作用:
可以用来维护数据库的完整性。
3.事务的四大特征(ACID):
原子性(Atomicity) :原子性是指事务是⼀个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
一致性(Consistency) :事务必须使数据库从⼀个⼀致性状态变换到另外⼀个⼀致性状态。
隔离性(Isolation) :事务的隔离性是多个⽤户并发访问数据库时,数据库为每⼀个⽤户开启的事务, 每个事务不能被其他事务的操作数据所⼲扰,多个并发事务之间要相互隔离。
持久性(Durability):持久性是指⼀个事务⼀旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。
4.入门案例
4.1添加spring事务管理(添加Transactional)
public interface AccountService {
//配置当前接口方法具有事务
@Transactional
public void transfer(String out,String in ,Double money) ;
}
4.2配置事务管理器
//配置事务管理器,mybatis使用的是jdbc事务
@Bean
public PlatformTransactionManager transactionManager(DataSource dataSource){
DataSourceTransactionManager dtm = new DataSourceTransactionManager();
transactionManager.setDataSource(dataSource);
return transactionManager;
}
4.3开启注解事务驱动
@Configuration
@ComponentScan("com.zhondianzhan")
@PropertySource("classpath:jdbc.properties")
@Import({JdbcConfig.class,MybatisConfig.class})
//开启注解式事务驱动
@EnableTransactionManagement
public class SpringConfig {
}
4.4启动单元测试
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = SpringConfig.class)
public class AccountServiceTest {
@Autowired
private AccountService accountService;
@Test
public void testTransfer() throws IOException {
accountService.transfer("Tom","Jerry",100D);
}
}