首页 > 代码库 > 第六章 springboot + 事务
第六章 springboot + 事务
在实际开发中,其实很少会用到事务,一般情况下事务用的比较多的是在金钱计算方面。
mybatis与spring集成后,其事务该怎么做?其实很简单,直接在上一节代码的基础上在相应的方法(通常是service层)上加上@Transactional注解即可。
1、com.xxx.firstboot.exception.UserException
package com.xxx.firstboot.exception;import org.springframework.dao.DataAccessException;/** * 自定义异常,用于测试事务 */public class UserException extends DataAccessException{ private static final long serialVersionUID = 8901479830692029025L; public UserException(String msg) { super(msg); }}
说明:这是一个自定义注解,继承了DataAccessException类。
2、com.xxx.firstboot.dao.UserDao
public int insertUser(String username, String password){ return userMapper.insertUser(username, password); } public void testTransactional(String username){ throw new UserException("测试事务"); }
说明:该类中对于事务的测试只使用到了两个方法,第二个方法testTransactional抛出自定义的异常。
3、com.xxx.firstboot.service.UserService
@Transactional2 public void testTransaction(String username, String password){3 System.out.println(userDao.insertUser(username, password));4 userDao.testTransactional(username);5 }
说明:在该方法中调用了上述的userDao的两个方法。
第一个方法向数据库插入一条数据,第二个方法抛出我们的自定义异常,如果事务配置成功,那么第一个方法插入数据库会回滚,否则,插入数据成功。
4、com.xxx.firstboot.controller.UserController
@ApiOperation("测试事务") @ApiImplicitParams({ @ApiImplicitParam(paramType="query",name="username",dataType="String",required=true,value="http://www.mamicode.com/用户的姓名",defaultValue="http://www.mamicode.com/zhaojigang"), @ApiImplicitParam(paramType="query",name="password",dataType="String",required=true,value="http://www.mamicode.com/用户的密码",defaultValue="http://www.mamicode.com/wangna") }) @ApiResponses({ @ApiResponse(code=400,message="请求参数没填好"), @ApiResponse(code=404,message="请求路径没有或页面跳转路径不对") }) @RequestMapping(value="/testTransaction",method=RequestMethod.GET) public void testTransaction(@RequestParam("username") String username, @RequestParam("password") String password) { userService.testTransaction(username, password); }
测试:
使用maven命令启动服务-->swagger运行URL-->查看数据库是否插入成功
疑问:查了很多资料,mybatis与springboot集成后(数据源采用了druid),为了添加事务,很多人会在上一节的MyBatisConfig这个类中做两件事请
- 在MyBatisConfig类上添加@EnableTransactionManagement注解,该注解启用了注解式事务管理 <tx:annotation-driven />,这样在方法上的@Transactional注解就起作用了,但是实际测试中不加这句,@Transactional注解依然有用
- 在MyBatisConfig类中添加了获取事务管理器的方法
/**2 * 配置事务管理器3 */4 @Bean5 @Primary6 public DataSourceTransactionManager transactionManager() throws Exception{7 return new DataSourceTransactionManager(getDataSource());8 }
添加这句的作用:在使用@Transactional注解的地方使用方法中的事务管理器进行事务管理。
第六章 springboot + 事务
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。