springboot aop事务,spring事务管理详解

  springboot aop事务,spring事务管理详解

  

目录

转账案例-环境搭建步骤1:准备数据库表步骤2:创建项目导入冲突包步骤3:根据表创建模型类步骤4:创建大刀接口步骤5:创建服务接口和实现类步骤6:添加jdbc.properties文件步骤7:创建JdbcConfig配置类步骤8:创建MybatisConfig配置类步骤9:创建弹簧配置配置类步骤10:编写测试类事务管理

 

  

转账案例-环境搭建

 

  

步骤1:准备数据库表

之前我们在整合框架的时候已经创建了这个表,可以直接使用

 

  创建数据库春天_数据库字符集utf8使用春天_数据库创建表tbl_account(id int主键auto_increment,name varchar(35),money double);插入到tbl _帐户值中(《汤姆》,1000);插入到tbl _帐户值(2、《杰里》,1000);

  

步骤2:创建项目导入jar包

项目的pom.xml添加相关依赖

 

  依赖项依赖项groupIdorg.springframework/groupId工件id spring-context/工件id version5.2.10.RELEASE/version/依赖项依赖项groupIdcom.alibaba/groupId神器id德鲁伊/神器id版本1 .1 .16/版本/依赖项依赖项groupIdorg.mybatis/groupId工件id my batis/工件id版本3 .5 .6/版本/依赖项依赖项groupId MySQL/groupId工件Id MySQL-connector-Java/工件id版本5 .1 .47/版本/依赖项依赖项groupIdorg.springframework/groupId神器id春天-JDBC/神器id version5.2.10.RELEASE/version/依赖项groupIdorg.mybatis/groupId神器id my batis-spring/神器

  5.2.10.RELEASE</version> </dependency> </dependencies>

 

  

步骤3:根据表创建模型类

public class Account implements Serializable { private Integer id; private String name; private Double money;//setter...getter...toString...方法略 }

 

  

步骤4:创建Dao接口

public interface AccountDao { @Update("update tbl_account set money = money + #{money} where name = #{name}") void inMoney(@Param("name") String name, @Param("money") Double money); @Update("update tbl_account set money = money - #{money} where name = #{name}") void outMoney(@Param("name") String name, @Param("money") Double money);}

 

  

步骤5:创建Service接口和实现类

public interface AccountService { /** * 转账操作 * @param out 传出方 * @param in 转入方 * @param money 金额 */ public void transfer(String out,String in ,Double money) ;}@Servicepublic class AccountServiceImpl implements AccountService { @Autowired private AccountDao accountDao; public void transfer(String out,String in ,Double money) { accountDao.outMoney(out,money); accountDao.inMoney(in,money); }}

 

  

步骤6:添加jdbc.properties文件

jdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://localhost:3306/spring_db?useSSL=falsejdbc.username=rootjdbc.password=root

 

  

步骤7:创建JdbcConfig配置类

public class JdbcConfig { @Value("${jdbc.driver}") private String driver; @Value("${jdbc.url}") private String url; @Value("${jdbc.username}") private String userName; @Value("${jdbc.password}") private String password; @Bean public DataSource dataSource(){ DruidDataSource ds = new DruidDataSource(); ds.setDriverClassName(driver); ds.setUrl(url); ds.setUsername(userName); ds.setPassword(password); return ds; }}

 

  

步骤8:创建MybatisConfig配置类

public class MybatisConfig { @Bean public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource){ SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean(); ssfb.setTypeAliasesPackage("com.itheima.domain"); ssfb.setDataSource(dataSource); return ssfb; } @Bean public MapperScannerConfigurer mapperScannerConfigurer(){ MapperScannerConfigurer msc = new MapperScannerConfigurer(); msc.setBasePackage("com.itheima.dao"); return msc; }}

 

  

步骤9:创建SpringConfig配置类

@Configuration@ComponentScan("com.itheima")@PropertySource("classpath:jdbc.properties")@Import({JdbcConfig.class,MybatisConfig.class})public class SpringConfig {}

 

  

步骤10:编写测试类

@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); }}

 

  

事务管理

上述环境,运行单元测试类,会执行转账操作,Tom的账户会减少100,Jerry的账户会加100。

 

  这是正常情况下的运行结果,但是如果在转账的过程中出现了异常,如:

  

@Servicepublic class AccountServiceImpl implements AccountService { @Autowired private AccountDao accountDao; public void transfer(String out,String in ,Double money) { accountDao.outMoney(out,money); int i = 1/0; accountDao.inMoney(in,money); }}

以上就是Spring AOP事务管理的示例详解的详细内容,更多关于Spring AOP事务管理的资料请关注盛行IT其它相关文章!

 

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: