Java Spring事务使用及验证过程详解
时间:2021-04-09 09:00:06|栏目:JAVA代码|点击: 次
事务,只要是为了保证数据的原子性。避免出现脏数据。
下面来讲解下spring是如何使用事务的。
1.配置事务。这里采用的是注解的模式
<!-- 配置事务管理器 ,如果你暂时未使用到事务可以不配置,次以下内容均可以在不适用事务的情况下删除 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager" > <property name="dataSource" ref="dataSource"/> </bean> <!-- 开启事务行为 --> <tx:annotation-driven transaction-manager="transactionManager" />
2.配置就基本搞定了,然后就是在service或者service的方法上使用@Transactional定义是否需要是否管理就行了。
@Transactional
@Override
public String userInfoData(String id) {
// TODO Auto-generated method stub
System.out.print("调用 dao层方法");
UserInfo arr = loginDao.getUser(1);
System.out.println("arr id = "+ arr.getId());
System.out.println("arr Username = "+ arr.getUsername());
MoneyInfo money = moneyDao.getmoney(1);
moneyDao.InsertMony(500);
loginDao.InsertUser(3, "Tigger");
System.out.println("money = "+ money.getMoney());
System.out.println("money += "+ money.getMoney());
Logger log = Logger.getLogger(UserServiceImpl.class);
log.info("执行了m01...");
//1.mybatis 的自己调用方法
/* try {
mybatisTest();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}*/
//2.spring + mybatis整合后的调用
return null;
}
以上就基本可以搞定了,验证配置是否成功的话,可以在不加注解的时候插入两条数据,后面一条数据是会报错的。
如果不使用事务的话,会发现第一条插入成功到DB里去了,然后在插入第二条的时候,程序报错。
如果这里使用@Transactional 开启事务,那么会发现两条数据都插入不了,直接报错了,这里事务就成功的启用了起来。
@Transactional
(1)这里说明一下,有的把这个注解放在类名称上面了,这样你配置的这个@Transactional 对这个类中的所有public方法都起作用.
(2)@Transactional 方法方法名上,只对这个方法有作用,同样必须是public的方法
(3) 数据库引擎要支持事务,如果是MySQL,注意表要使用支持事务的引擎,比如innodb,如果是myisam,事务是不起作用的
栏 目:JAVA代码
本文地址:http://www.codeinn.net/misctech/97549.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




