Spring 事务

特性

ACID:原子性,一致性,隔离性,持久性。

事务是一个不可分割的操作,其中的过程要么全部成功要么全部失败。一旦完成后会统一提交来保证一致性。

不同的事务处理统一数据是隔离的,防止数据的损坏。事务的结果会被永久的保存。

分类

  • 编程式事务

将事务管理代码嵌到业务方法中来控制事务的提交和回滚

缺点:必须在每个事务操作业务逻辑中包含额外的事务管理代码

  • 声明式事务

将事务管理代码从业务方法中分离出来,以声明的方式来实现事务管理。

将事务管理作为横切关注点,通过aop方法模块化。

编程式事务

public class UserMapperImpl1 extends SqlSessionDaoSupport implements UserMapper{
    private final PlatformTransactionManager transactionManager;
    public UserMapperImpl1(PlatformTransactionManager transactionManager) {
        this.transactionManager = transactionManager;
    }
    @Override
    public List<User> selectUser() {
        return getSqlSession().getMapper(UserMapper.class).selectUser();
    }

    @Override
    public int addUser(User user) {
        int a=0;
        TransactionStatus txStatus =
                transactionManager.getTransaction(new DefaultTransactionDefinition());
        try{
            getSqlSession().getMapper(UserMapper.class).addUser(user);
            getSqlSession().getMapper(UserMapper.class).deleteUser(10);
        }catch (Exception e){
            transactionManager.rollback(txStatus);
            throw e;
        }
        return a;
    }
  /* 此处和上述一致  
//        TransactionTemplate transactionTemplate = new TransactionTemplate(transactionManager);
//        a = transactionTemplate.execute(txStatus -> {
//            getSqlSession().getMapper(UserMapper.class).addUser(user);
//            getSqlSession().getMapper(UserMapper.class).deleteUser(10);
//            return null;
//        });
    @Override
    public int deleteUser(Integer id) {
        return getSqlSession().getMapper(UserMapper.class).deleteUser(id);
    }
}

声明式事务

常用两种传播方式:

  • propagation_requierd:如果当前没有事务,就新建一个事务,如果已存在一个事务中,加入到这个事务中,这是最常见的选择。
  • propagation_nested:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与propagation_required类似的操作。

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:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
   http://www.springframework.org/schema/tx
   http://www.springframework.org/schema/tx/spring-tx-4.3.xsd http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd">
    <!--   引入数据源 -->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/test?useSSL=false&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>
    <!--    引入SQL工厂-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <!--        关联mybatis配置-->
        <property name="typeAliases" value="com.spring.pojo.User"/>
        <!--        扫描包-->
        <property name="mapperLocations" value="classpath:com/spring/mapper/*.xml"></property>
    </bean>
    <!--    注册sqlSessionTemplate , 关联sqlSessionFactory-->
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
        <!--利用构造器注入-->
        <constructor-arg index="0" ref="sqlSessionFactory"/>
    </bean>
<!--    配置声明式事务-->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <bean id="userMapper" class="com.spring.mapper.UserMapperImpl">
        <property name="sqlSessionFactory" ref="sqlSessionFactory"/>
    </bean>

    <!--配置事务通知-->
    <!--结合AOP实现事务的织入-->
    <!--配置事务通知-->
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <!--给那些方法配置事务-->
        <!--配置事务的传播特性: new -->
        <tx:attributes>
            <tx:method name="addUser" propagation="REQUIRED"/>
            <tx:method name="deleteUser" propagation="REQUIRED"/>
            <tx:method name="updateUser" propagation="REQUIRED"/>
            <tx:method name="selectUser" read-only="true"/>
<!--            <tx:method name="*" propagation="REQUIRED"/>-->
        </tx:attributes>
    </tx:advice>
    <aop:config>
        <aop:pointcut id="txPointCut" expression="execution(* com.spring.mapper.UserMapper.*(..))"/>
        <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointCut"/>
    </aop:config>
</beans>

JAVA类:

public class UserMapperImpl extends SqlSessionDaoSupport implements UserMapper{
    @Override
    public List<User> selectUser() {
        int a1 = getSqlSession().getMapper(UserMapper.class).addUser(new User(12,"wxn1"));
        return getSqlSession().getMapper(UserMapper.class).selectUser();
    }

    @Override
    public int addUser(User user) {
        System.out.println("新增开始");
        int a = getSqlSession().getMapper(UserMapper.class).addUser(user);
        System.out.println("新增结束");
        return a;
    }

    @Override
    public int deleteUser(@Param(value = "id") Integer id) {
        System.out.println("删除开始");
        int a1 = getSqlSession().getMapper(UserMapper.class).addUser(new User(12,"wxn1"));
        int a2 = getSqlSession().getMapper(UserMapper.class).deleteUser(id);
        System.out.println("删除结束");
        return a2;
    }
}

测试类:

public void selectUser() {
        ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
        UserMapper userMapper = context.getBean("userMapper", UserMapper.class);
//        userMapper.addUser(new User(8,"丽丽1"));
//        userMapper.deleteUser(10);
        for (User user : userMapper.selectUser()) {
            System.out.println(user);
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值