From 3b21508b32863859ff427b7c7f2b8d156da159e5 Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期四, 10 十月 2019 00:27:35 +0800
Subject: [PATCH] 优化mapper问价加载
---
java110-db/src/main/java/com/java110/db/MyBatisConfig.java | 25 ++++++++++++++++++++++---
1 files changed, 22 insertions(+), 3 deletions(-)
diff --git a/java110-db/src/main/java/com/java110/db/MyBatisConfig.java b/java110-db/src/main/java/com/java110/db/MyBatisConfig.java
index e831576..8c8bcd6 100644
--- a/java110-db/src/main/java/com/java110/db/MyBatisConfig.java
+++ b/java110-db/src/main/java/com/java110/db/MyBatisConfig.java
@@ -1,13 +1,13 @@
package com.java110.db;
-import com.alibaba.druid.pool.DruidDataSource;
+import com.java110.config.properties.code.Java110Properties;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
+import org.springframework.core.io.Resource;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.core.io.support.ResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
@@ -16,6 +16,9 @@
import org.springframework.transaction.annotation.TransactionManagementConfigurer;
import javax.sql.DataSource;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
/**
* MyBatis鍩虹閰嶇疆
@@ -26,6 +29,9 @@
@Configuration
@EnableTransactionManagement
public class MyBatisConfig implements TransactionManagementConfigurer {
+
+ @Autowired
+ private Java110Properties java110Properties;
@Autowired
DataSource dataSource;
@@ -47,7 +53,14 @@
//娣诲姞XML鐩綍
ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
try {
- bean.setMapperLocations(resolver.getResources("classpath:mapper/*/*.xml"));
+ // bean.setMapperLocations(resolver.getResources("classpath:mapper/*/*.xml"));
+ Resource[] resources = null;
+ List<Resource> resourceList = new ArrayList<Resource>();
+ for(String path : java110Properties.getMappingPath().split(",")) {
+ resources = resolver.getResources(path);
+ resourceList.addAll(Arrays.asList(resources));
+ }
+ bean.setMapperLocations(resourceList.toArray(new Resource[resourceList.size()]));
return bean.getObject();
} catch (Exception e) {
e.printStackTrace();
@@ -66,5 +79,11 @@
return new DataSourceTransactionManager(dataSource);
}
+ public Java110Properties getJava110Properties() {
+ return java110Properties;
+ }
+ public void setJava110Properties(Java110Properties java110Properties) {
+ this.java110Properties = java110Properties;
+ }
}
--
Gitblit v1.8.0