美文网首页
Spring_11_1 Transaction(事务) 使用(注

Spring_11_1 Transaction(事务) 使用(注

作者: mm_cuckoo | 来源:发表于2017-10-07 22:45 被阅读65次

在Spring 中使用注解配置 Transaction (事务) ,如果会使用XML配置方式,那么就会发现注解更加方便高效。

XML进行必要配置

  1. 配置事务管理器
<bean id="cPDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
    <property name="driverClass" value="com.mysql.jdbc.Driver" />
    <property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3306/spring_db?useUnicode=true&amp;characterEncoding=UTF-8" />
    <property name="user" value="root" />
    <property name="password" value="root" />
</bean>

<!-- 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <!-- 注入DataSource -->
    <property name="dataSource" ref="cPDataSource"></property>
</bean>
  1. 开启事务注解
<!-- 开启事务注解 -->
<tx:annotation-driven transaction-manager="transactionManager"/>

上面两步,配置基本完成,下面就是添加事务

在Spring 中添加事务

在Spring 中向一个类中添加事务也是非常方便的,只要在类上添加@Transactional注解就可以可。

示例代码

<?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:aop="http://www.springframework.org/schema/aop" 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/tx 
        http://www.springframework.org/schema/tx/spring-tx.xsd
        http://www.springframework.org/schema/aop 
        http://www.springframework.org/schema/aop/spring-aop.xsd">

    <bean id="cPDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="com.mysql.jdbc.Driver" />
        <property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3306/spring_db?useUnicode=true&amp;characterEncoding=UTF-8" />
        <property name="user" value="root" />
        <property name="password" value="root" />
    </bean>
    
    <!-- 1.配置事务管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <!-- 注入DataSource -->
        <property name="dataSource" ref="cPDataSource"></property>
    </bean>
    
    <!-- 2. 开启事务注解 -->
    <tx:annotation-driven transaction-manager="transactionManager"/>
    
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <property name="dataSource" ref="cPDataSource" />
    </bean>
    
    <bean id="userService" class="com.cfox.spring.UserService">
        <property name="userDao" ref="userDao"/>
    </bean>
    
    <bean id="userDao" class="com.cfox.spring.UserDao">
        <property name="jdbcTemplate" ref="jdbcTemplate"></property>
    </bean>
</beans>
@Transactional
public class UserService {
    
    private UserDao userDao;
    public void setUserDao(UserDao userDao) {
        this.userDao = userDao;
    }

    public void updateUserMoney() {
        userDao.updateMoney("王五", 1000);
        int a = 10 / 0;
        userDao.updateMoney("李四", -1000);
    }
}

public class UserDao {
    
    private JdbcTemplate jdbcTemplate;
    
    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

    public void updateMoney(String name, int money) {
        String sql = "UPDATE user_acc SET salary=salary+? WHERE user_name=?";
        int row = jdbcTemplate.update(sql, money, name);
        System.out.println(row);
    }
}

相关文章

  • Spring_11_1 Transaction(事务) 使用(注

    在Spring 中使用注解配置 Transaction (事务) ,如果会使用XML配置方式,那么就会发现注解更加...

  • Yii2 事务

    事务(Transaction) 在Yii中,使用 yii\db\Transaction 来表示数据库事务。 一般情...

  • WCDB 入门

    iOS+macOS使用教程 ORM使用教程 demo 事务一 事务二 事务(Transaction),一般是指要做...

  • @Transaction使用&@事务失效

    Transaction是Spring提供的关于事务的支持,Spring事务管理分为编码式和声明式两种方式。声明式事...

  • 谈谈Transaction——MySQL事务处理分析

    MySQL 事务基础概念/Definition of Transaction 事务(Transaction)是访问...

  • 第二章1.0初识Spring

    JDBC Template --使用了 模板模式ORM --使用了策略模式 Transaction 事务管理 ...

  • MySQL白菜教程(Level 8)

    MySQL Transaction MySQL 事务以及如何使用 COMMIT 和 ROLLBACK 语句来管理 ...

  • 数据库

    开启事务:备份。BEGIN TRANSACTION提交事务:删除备份。COMMIT TRANSACTION回滚:用...

  • mysql

    事务控制语句: BEGIN 或 START TRANSACTION 显式地开启一个事务; COMMIT 也可以使用...

  • 事务

    2.事务的语句开始事物:BEGIN TRANSACTION提交事物:COMMIT TRANSACTION回滚事务:...

网友评论

      本文标题:Spring_11_1 Transaction(事务) 使用(注

      本文链接:https://www.haomeiwen.com/subject/zemsyxtx.html