最近項目使用了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;
}
}