zoukankan      html  css  js  c++  java
  • spring4声明式事务--01注解方式

    1.在spring配置文件中引入 tx 命名空间

    xmlns:tx="http://www.springframework.org/schema/tx"

    2.配置事务管理器

    <!-- 配置事物管理器 -->
        <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <property name="dataSource" ref="dataSource"></property>
        </bean>

    3.启用事务注解

     

    <!-- 启用事务注解-->
    <tx:annotation-driven transaction-manager="transactionManager"/>

    4.在相应的业务代码方法上方加 @Transactional 表明此方法受事务管理

    //spring的声明式事务
        @Transactional
        @Override
        public void purchase(String isbn, String userName) {
            //1.根据书号找价格
            int price=bookShopDao.findPriceByIsbn(isbn);
            
            //2.库存-1
            bookShopDao.updateBookStock(isbn);
            
            //3.账户余额-price
            bookShopDao.updateAccount(userName, price);
        }

     

     事务的属性:  
        1.使用 propagation 声明事务的传播属性,默认即 REQUIRED 即被包含在上面的事务中,放弃自己处理事务
        REQUIRES_NEW 以本方法为执行单位,开启一个新事务(外部事务在方法执行前后被挂起)
        
        2.使用 isolation 指定事务的隔离级别,最常用的取值为 READ_COMMITTED 读与提交
    
        3.默认情况下Spring 的声明式事务对所有的运行时一样长进行回滚。
        也可以对应的属性指定配置,通常情况下取默认值即可。使用 noRollbackFor 指定不回滚的异常,其他的类似
    
        4.使用 readOnly 指定事务是否为只读,表示这个事务只读取数据但不更新数据,
        这样可以帮助数据库引擎优化事务。若真的是一个只读取数据库值得方法,应设置readOnly=true
        
        5.使用 timeout 指定强制回滚之前事务可以占用的时间
  • 相关阅读:
    Oracle分析函数row_number()等的使用实例
    Oracle行列转换case when then方法案例
    Oracle日期函数
    Oracle转换函数
    Oracle数值函数
    Oracle字符函数length substr concat实例
    Oracle列转行函数LISTAGG()
    Oracle 条件判断函数decode和case when then案例
    Oracle NVL空值处理函数
    【学亮开讲】Oracle内外连接查询20181119
  • 原文地址:https://www.cnblogs.com/qq-757617012/p/4295338.html
Copyright © 2011-2022 走看看