Spring事务管理+AOP实现银行转账功能
使用xml版+注解版(已注掉)配置实现
第一步 建库建表
第二步 创建Dao层接口及其实现类
在Dao层实现两个方法,一个是转出的方法,一个是转入的方法,有个共同点,就是都要知道是谁转的帐(id),转了多少钱(money),在转出的同时,要转入相同的钱数
/**@文件名: BankTransferMoneyDao.java
* @类功能说明: 银行转账Dao层接口
* @作者: LiYuHui
* @Email: 1327711913@qq.com
* @日期: 2020年6月22日下午4:56:55
* @修改说明:<br>
* <pre>
* <li>作者: LiYuHui</li>
* <li>日期: 2020年6月22日下午4:56:55</li>
* <li>内容: </li>
* </pre>
*/
public interface BankTransferMoneyDao {
/**
* @方法名: outMoney
* @方法说明: 转出
* @作者: LiYuHui
* @邮箱:1327711913@qq.com
* @日期: 2020年6月22日下午5:18:01
* @param money
* @param user_id
* @return: void
*/
public void outMoney(double money,int user_id);
/**
* @方法名: inMoney
* @方法说明: 转入
* @作者: LiYuHui
* @邮箱:1327711913@qq.com
* @日期: 2020年6月22日下午5:18:49
* @param money
* @param user_id
* @return: void
*/
public void inMoney(double money,int user_id);
}
/**@文件名: BankTransferMoneyDaoImpl.java
* @类功能说明: 银行转账的Dao层接口的实现类
* @作者: LiYuHui
* @Email: 1327711913@qq.com
* @日期: 2020年6月22日下午5:20:11
* @修改说明:<br>
* <pre>
* <li>作者: LiYuHui</li>
* <li>日期: 2020年6月22日下午5:20:11</li>
* <li>内容: </li>
* </pre>
*/
public class BankTransferMoneyDaoImpl implements BankTransferMoneyDao {
//注入带参数的JDBC模板
private NamedParameterJdbcTemplate namedParameterJdbcTemplate;
public void setNamedParameterJdbcTemplate(NamedParameterJdbcTemplate namedParameterJdbcTemplate) {
this.namedParameterJdbcTemplate = namedParameterJdbcTemplate;
}
/**
* 转出
*/
@Override
public void outMoney(double money, int user_id) {
String sql = "update t_count set money=money-:money where user_id=:id";
MapSqlParameterSource msps = new MapSqlParameterSource();
msps.addValue("money", money);
msps.addValue("id", user_id);
namedParameterJdbcTemplate.update(sql, msps);
}
/**
* 转入
*/
@Override
public void inMoney(double money, int user_id) {
String sql = "update t_count set money=money+:money where user_id=:id";
MapSqlParameterSource msps = new MapSqlParameterSource();
msps.addValue("money", money);
msps.addValue("id", user_id);
namedParameterJdbcTemplate.update(sql, msps);
}
}
第三步 创建Service接口及其实现类
Service层是处理业务逻辑的,在该层完成转账操作,转账需要知道:1、要转的钱数,2、谁转的钱,3、要转给谁
/**@文件名: BankTransferMoneyService.java
* @类功能说明: 银行转账的service接口
* @作者: LiYuHui
* @Email: 1327711913@qq.com
* @日期: 2020年6月22日下午5:28:49
* @修改说明:<br>
* <pre>
* <li>作者: LiYuHui</li>
* <li>日期: 2020年6月22日下午5:28:49</li>
* <li>内容: </li>
* </pre>
*/
public interface BankTransferMoneyService {
/**
* @方法名: transferMoney
* @方法说明: 转账的方法
* @作者: LiYuHui
* @邮箱:1327711913@qq.com
* @日期: 2020年6月22日下午5:30:13
* @param money
* @param user_idA
* @param user_idB
* @return: void
*/
public void transferMoney(double money,int user_idA,int user_idB);
}
/**@文件名: BankTransferMoneyServiceImpl.java
* @类功能说明: 银行转账service层接口的实现类
* @作者: LiYuHui
* @Email: 1327711913@qq.com
* @日期: 2020年6月22日下午5:30:46
* @修改说明:<br>
* <pre>
* <li>作者: LiYuHui</li>
* <li>日期: 2020年6月22日下午5:30:46</li>
* <li>内容: </li>
* </pre>
*/
/*@Transactional*/
public class BankTransferMoneyServiceImpl implements BankTransferMoneyService {
//注入Dao
private BankTransferMoneyDao bankTransferMoneyDao;
public void setBankTransferMoneyDao(BankTransferMoneyDao bankTransferMoneyDao) {
this.bankTransferMoneyDao = bankTransferMoneyDao;
}
/**
* 转账
*/
@Override
public void transferMoney(double money, int user_idA, int user_idB) {
//转出
bankTransferMoneyDao.outMoney(money, user_idA);
//转入
bankTransferMoneyDao.inMoney(money, user_idB);
}
}
第四步 配置applicationContext.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
">
<!-- 创建数据源dataSource(dbcp连接池) -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/db_bank?useUnicode=true&characterEncoding=utf-8"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</bean>
<!-- 配置事务管理 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 注入数据源 -->
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 注入事务管理器(注解版) -->
<!-- <tx:annotation-driven transaction-manager="transactionManager"/> -->
<!-- 配置事务通知(XML版) -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 指定所有的方法 -->
<tx:method name="*"/>
</tx:attributes>
</tx:advice>
<!-- 配置事务切面 -->
<aop:config>
<aop:pointcut expression="execution(* com.lyh.service.*.*(..))" id="businessPoint"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="businessPoint"/>
</aop:config>
<!-- 创建带参数的JDBC模板 -->
<bean id="namedParameterJdbcTemplate" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
<constructor-arg ref="dataSource"></constructor-arg>
</bean>
<!-- 创建Dao层 -->
<bean id="bankTransferMoneyDao" class="com.lyh.dao.impl.BankTransferMoneyDaoImpl">
<!-- 注入带参数的JDBC模板 -->
<property name="namedParameterJdbcTemplate" ref="namedParameterJdbcTemplate"></property>
</bean>
<!-- 创建Service层 -->
<bean id="bankTransferMoneyService" class="com.lyh.service.impl.BankTransferMoneyServiceImpl">
<!-- 注入Dao层 -->
<property name="bankTransferMoneyDao" ref="bankTransferMoneyDao"></property>
</bean>
</beans>
第五步 编写JUnit测试类进行测试
/**@文件名: TransferMoneyTest.java
* @类功能说明: 转账测试类
* @作者: LiYuHui
* @Email: 1327711913@qq.com
* @日期: 2020年6月22日下午5:54:54
* @修改说明:<br>
* <pre>
* <li>作者: LiYuHui</li>
* <li>日期: 2020年6月22日下午5:54:54</li>
* <li>内容: </li>
* </pre>
*/
class TransferMoneyTest {
private ApplicationContext ac = null;
private BankTransferMoneyService bankTransferMoneyService = null;
@BeforeEach
void setUp() throws Exception {
ac = new ClassPathXmlApplicationContext("applicationContext.xml");
bankTransferMoneyService = (BankTransferMoneyService)ac.getBean("bankTransferMoneyService");
}
/**
* @方法名: transferMoney
* @方法说明: 转账测试
* @作者: LiYuHui
* @邮箱:1327711913@qq.com
* @日期: 2020年6月22日下午5:56:35
* @return: void
*/
@Test
public void transferMoney() {
bankTransferMoneyService.transferMoney(50, 1, 2);
}
}
需要导的包:
- dbcp:
- commons-dbcp-1.4.jar
- commons-pool.jar
- jdbc:
- mysql-connector-java-5.0.8-bin.jar
- springAOP:
- aopalliance.jar
- aspectjweaver-1.6.6.jar
- spring-aspects-4.0.6.RELEASE.jar
- Spring的Jdbc模板:
- spring-jdbc-4.0.6.RELEASE.jar
- spring-tx-4.0.6.RELEASE.jar
- spring核心jar包:
- commons-logging.jar
- spring-aop-4.0.6.RELEASE.jar
- spring-beans-4.0.6.RELEASE.jar
- spring-context-4.0.6.RELEASE.jar
- spring-core-4.0.6.RELEASE.jar
- spring-expression-4.0.6.RELEASE.jar