zoukankan      html  css  js  c++  java
  • spring 事务

    简单示例:

    1,spring 配置文件中配置事务,并开启

    <!-- dbcp 数据源 -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
      <property name="driverClassName" value="org.gjt.mm.mysql.Driver" />
      <property name="url" value="jdbc:mysql://localhost:3306/weipai?useUnicode=true&amp;characterEncoding=UTF-8" />
      <property name="username" value="root" />
      <property name="password" value="WeiPai_111111" />
    </bean>
        
    <!-- 配置事务管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
      <property name="dataSource" ref="dataSource" />
    </bean>
    <!-- 启用事务管理器 -->
    <tx:annotation-driven transaction-manager="transactionManager" />

    2,在方法上添加注解 @Transactional

    // 添加注解就搞定了,如果这个方法产生异常就回滚
    @Transactional
    public void addCart() {
        // 库存 -1
        // 购物车 +1
    }

    事务的传播属性

    REQUIRED:如果已经存在就使用当前事务,没有就新建,默认
    REQUIRES_NEW:如果已经存在事务就挂起,当前方法会新开一个事务

    @Transactional
    public void checkAccountBalance() {
        // 获取用户余额
        // 获取商品价格
        // 如果用户余额大于商品价格,添加到购物车
        addCart();
    }
        
    @Transactional(propagation=Propagation.REQUIRED)
    public void addCart() {
        // 库存 -1
        // 购物车 +1
    }

    事务的隔离级别

    参见 springboot 事务和 mysql 事务隔离级别博文

  • 相关阅读:
    JS实例
    第一章 机器学习基础
    事件与信号
    微信公众号开发实例
    php学记笔记之函数用途
    php漏洞修复 禁用函数
    删除MYSQL账号多于的空用户
    MySql 建表、添加字段、修改字段、添加索引SQL语句写法
    php对二维数据进行排序
    iis支持IPA和APK文件下载
  • 原文地址:https://www.cnblogs.com/huanggy/p/9503101.html
Copyright © 2011-2022 走看看