JavaSpring的jdbcTemplate事务

1、使用JdbcTemplate需要引入的依赖(spring的maven项目)

<!-- jdbcTemplate实现jar -->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>${spring.version}</version>
</dependency>
 
<!-- 数据库驱动 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.43</version>
</dependency>
 
<!-- 数据库连接池 -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.12</version>
</dependency>
<!-- 事务管理 -->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-tx</artifactId>
    <version>${spring.version}</version>
</dependency>

<!--上下文-->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.3.22</version>
</dependency>

<!--beans依赖-->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-beans</artifactId>
    <version>5.3.23</version>
</dependency>

<!--core核心-->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-core</artifactId>
    <version>5.3.22</version>
</dependency>

2、环境搭配----bean.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: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/tx http://www.springframework.org/schema/tx/spring-tx.xsd
                           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
    <!--组件扫描-->
    <context:component-scan base-package="com.lxh.spring5"></context:component-scan>
    <!--数据库连接池-->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
        <property name="url"  value="jdbc:mysql://localhost/user_db"></property>
        <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
        <property name="username" value="root"></property>
        <property name="password" value="laixinghai"></property>
    </bean>
    <!--JDBCTemplate-->
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <!--注入datasource-->
        <property name="dataSource" ref="dataSource"></property>
    </bean>
    <!--创建事务管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>
    <!--开启事务注解-->
    <tx:annotation-driven transaction-manager="transactionManager"></tx:annotation-driven>
</beans>

三、dao层代码

UserDao接口

public interface UserDao {

    // 加钱
    public void addMoney();

    // 减钱
    public void reduceMoney();

}

UserDaoImpl实现类

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;

@Repository
public class UserDaoImpl implements UserDao{

    // 注入JdbcTemplate
    @Autowired
    private JdbcTemplate jdbcTemplate;

    // 加钱
    @Override
    public void addMoney() {
        String sql = "update t_account set money=money+? where username=?";
        Object[] obj = new Object[] {100, "mary"};
        int update = jdbcTemplate.update(sql, obj);
        System.out.println(update);
    }

    // 减钱
    @Override
    public void reduceMoney() {
        String sql = "update t_account set money=money-? where username=?";
        Object[] obj = {100, "lucy"};
        int update = jdbcTemplate.update(sql, obj);
        System.out.println(update);
    }
}

4、service层代码

import com.lxh.spring5.dao.UserDao;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Isolation;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;

@Service(value = "userService")
// 事务注解
// propagation:传播行为
// isolation:隔离级别
@Transactional(propagation = Propagation.MANDATORY, isolation = Isolation.READ_COMMITTED)
public class UserService {

    // 注入dao
    @Autowired
    private UserDao userDao;

    //  转账的方法
    public void accountMoney(){
        // 原始方式
//        try {
//            // 1.开启事务
//
//            // 2.进行业务操作
//            // lucy减100
//            userDao.reduceMoney();
//            // 添加异常
//            int i = 10/0;
//            // mary加100
//            userDao.addMoney();
//
//            // 3.没有异常提交事务
//        }catch (Exception e)  {
//            // 4.出现异常事务回滚
//        }

        // 加Transactional注解后
        // lucy减100
        userDao.reduceMoney();
        // 添加异常
        int i = 10/0;
        // mary加100
        userDao.addMoney();
    }
}

5、测试代码

import com.lxh.spring5.service.UserService;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Demo {

    @Test
    public void  testAccountMoney()  {
        ApplicationContext context = new ClassPathXmlApplicationContext("bean.xml");

        UserService userService = context.getBean("userService", UserService.class);

        userService.accountMoney();
    }
}

 

posted @ 2022-10-05 08:13  lai_xinghai  阅读(128)  评论(0)    收藏  举报