Springboot+Jfinal事務管理,事務交給Spring管理

最近項目使用了Jfinal+Springboot框架,第一次使用JFinal,也有了一些感受,在做到配置事務的時候找了網(wǎng)上的文章比較少。最終自己配置出來了一個,記錄一下,讓以后遇到這個需求的伙伴少走彎路。直接上代碼吧。

下面是需要用到的配置文件截圖,6.0以上數(shù)據(jù)庫版本請使用com.mysql.cj.jdbc這個驅動

image.png

上代碼:


import javax.sql.DataSource;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.jdbc.datasource.TransactionAwareDataSourceProxy;
import com.alibaba.druid.pool.DruidDataSource;
import com.boss.sms.entity._MappingKit;
import com.jfinal.plugin.activerecord.ActiveRecordPlugin;
import com.jfinal.plugin.activerecord.dialect.MysqlDialect;

/**
 * @Data : 2020年4月27日
 * @author : Leaual
 * @description : JFinal配置類
 */

@Configuration
public class JFinalConfig  {
    
 // 將全局配置提出來 方便其它地方重用
//    private static Prop prop = PropKit.use("application-dev.properties");
    
    /**
     * 初始化連接池
     * @return
     */
    @Bean
    @Primary
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource druidDataSource() {
        return new DruidDataSource();
    }
    
    /**
     * 配置數(shù)據(jù)源代理
     * @return
     */
    @Bean
    public TransactionAwareDataSourceProxy transactionAwareDataSourceProxy() {
        TransactionAwareDataSourceProxy transactionAwareDataSourceProxy = new TransactionAwareDataSourceProxy();
        transactionAwareDataSourceProxy.setTargetDataSource(druidDataSource());
        return transactionAwareDataSourceProxy;
    }
    
    /**
     * 配置事務管理
     * @return
     */
    @Bean
    public DataSourceTransactionManager dataSourceTransactionManager() {
        DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager();
        dataSourceTransactionManager.setDataSource(transactionAwareDataSourceProxy());
        return dataSourceTransactionManager;
    }

    

    /**
     * 配置ActiveRecord
     * @return
     */
    @Bean
    public ActiveRecordPlugin getActiveRecordPlugin() {
          // 下面注釋掉的是之前使用Jfinal自己的插件形式讀取的數(shù)據(jù)庫連接信息
//        DruidPlugin druidPlugin = new DruidPlugin(prop.get("url"), prop.get("user"), prop.get("password"));
//        druidPlugin.setDriverClass("com.mysql.jdbc.Driver");
//        druidPlugin.start();
        
        ActiveRecordPlugin arp = new ActiveRecordPlugin(transactionAwareDataSourceProxy());
        arp.setShowSql(true);
        arp.setDialect(new MysqlDialect());

        _MappingKit.mapping(arp);
        arp.start();
        return arp;
    }
    
    
    
}

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容