zoukankan      html  css  js  c++  java
  • spring boot 中 事务配置

    package org.whm.appcore;
    
    import java.util.Properties;
    
    import javax.sql.DataSource;
    
    import org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.context.annotation.Bean;
    import org.springframework.jdbc.datasource.DataSourceTransactionManager;
    import org.springframework.stereotype.Component;
    import org.springframework.transaction.interceptor.TransactionInterceptor;
    
    @Component
    public class TxConfig {
    
        // 创建事务管理器
        @Bean(name = "txManager")
        public DataSourceTransactionManager getTx(@Autowired DataSource ds) {
            DataSourceTransactionManager dsTx = new DataSourceTransactionManager(ds);
            return dsTx;
        }
    
        // 创建事务通知。。
    
        @Bean(name = "txAdvice")
        public TransactionInterceptor getAdvisor(@Qualifier("txManager") DataSourceTransactionManager txManager)
                throws Exception {
            TransactionInterceptor tsi = new TransactionInterceptor();
            Properties properties = new Properties();
            properties.setProperty("get*", "PROPAGATION_REQUIRED,-Exception,readOnly");
            properties.setProperty("add*", "PROPAGATION_REQUIRED,-Exception,readOnly");
            properties.setProperty("save*", "PROPAGATION_REQUIRED,-Exception,readOnly");
            properties.setProperty("update*", "PROPAGATION_REQUIRED,ISOLATION_DEFAULT,-Exception,readOnly");
    
            tsi.setTransactionAttributes(properties);
            return tsi;
    
        }
    
        @Bean
        public BeanNameAutoProxyCreator txProxy() {
            BeanNameAutoProxyCreator creator = new BeanNameAutoProxyCreator();
            creator.setInterceptorNames("txAdvice");
            creator.setBeanNames("*Service", "*ServiceImpl");
            creator.setProxyTargetClass(true);
            return creator;
        }
    }
  • 相关阅读:
    ALV_TREE(二:cl_gui_simple_tree…
    ALV_TREE(一:cl_gui_alv_tree_si…
    SQLPlus命令详细说明
    PL/SQL中,declare定义变量和variable定义变量的区别?
    Oracle 多表视图更新(待看完触发器后再来看)
    Oracle 函数 Translate 的用法
    Merge into
    savepoint(回退点)
    Oracle之分页查询
    对于package中全局变量的一点点初级理解
  • 原文地址:https://www.cnblogs.com/whm-blog/p/7262101.html
Copyright © 2011-2022 走看看