src/main/java/com/lf/server/controller/all/BaseQueryController.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/lf/server/helper/ClassHelper.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/lf/server/service/all/BaseQueryService.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/lf/server/service/data/DataLoaderService.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
src/main/java/com/lf/server/controller/all/BaseQueryController.java
@@ -11,6 +11,7 @@ import com.lf.server.entity.data.DictEntity; import com.lf.server.entity.data.DomainEntity; import com.lf.server.helper.AesHelper; import com.lf.server.helper.ClassHelper; import com.lf.server.helper.StringHelper; import com.lf.server.mapper.all.BasicMapper; import com.lf.server.mapper.all.GeomBaseMapper; @@ -43,7 +44,7 @@ @PostMapping(value = "/selectCount") public ResponseMsg<Long> selectCount(String name, String filter, String wkt) { try { BasicMapper baseMapper = baseQueryService.getBasicMapper(name); BasicMapper baseMapper = ClassHelper.getBasicMapper(name); if (baseMapper == null) { return fail("查询对象不存在", null); } @@ -74,7 +75,7 @@ @PostMapping(value = "/selectByPage") public ResponseMsg<List<Object>> selectByPage(String name, String filter, String wkt, Integer pageIndex, Integer pageSize) { try { BasicMapper baseMapper = baseQueryService.getBasicMapper(name); BasicMapper baseMapper = ClassHelper.getBasicMapper(name); if (baseMapper == null) { return fail("查询对象不存在", null); } @@ -102,7 +103,7 @@ @GetMapping(value = "/selectWktById") public ResponseMsg<String> selectWktById(String name, Integer gid) { try { GeomBaseMapper baseMapper = baseQueryService.getGeoBaseMapper(name); GeomBaseMapper baseMapper = ClassHelper.getGeoBaseMapper(name); if (baseMapper == null) { return fail("查询对象不存在", null); } @@ -133,7 +134,7 @@ @GetMapping(value = "/selectFieldFuzzy") public ResponseMsg<List<String>> selectFieldFuzzy(String name, String field, String value) { try { BasicMapper baseMapper = baseQueryService.getBasicMapper(name); BasicMapper baseMapper = ClassHelper.getBasicMapper(name); if (baseMapper == null) { return fail("查询对象不存在", null); } @@ -211,7 +212,7 @@ @GetMapping(value = "/selectFields") public ResponseMsg<List<DictEntity>> selectFields(String name) { try { BasicMapper baseMapper = baseQueryService.getBasicMapper(name); BasicMapper baseMapper = ClassHelper.getBasicMapper(name); if (baseMapper == null) { return fail("查询对象不存在", null); } @@ -238,7 +239,7 @@ @GetMapping(value = "/selectDomains") public ResponseMsg<List<DomainEntity>> selectDomains(String name) { try { BasicMapper baseMapper = baseQueryService.getBasicMapper(name); BasicMapper baseMapper = ClassHelper.getBasicMapper(name); if (baseMapper == null) { return fail("查询对象不存在", null); } src/main/java/com/lf/server/helper/ClassHelper.java
@@ -1,6 +1,8 @@ package com.lf.server.helper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.lf.server.mapper.all.BasicMapper; import com.lf.server.mapper.all.GeomBaseMapper; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.springframework.aop.support.AopUtils; @@ -50,6 +52,44 @@ } /** * 获取父Mapper * * @param name Mapper名 * @return BaseMapper */ public static BasicMapper getBasicMapper(String name) { if (StringHelper.isEmpty(name)) { return null; } Object obj = getBean(name.trim() + "Mapper"); if (!(obj instanceof BasicMapper)) { return null; } return (BasicMapper) obj; } /** * 获取空间父Mapper * * @param name Mapper名 * @return GeomBaseMapper */ public static GeomBaseMapper getGeoBaseMapper(String name) { if (StringHelper.isEmpty(name)) { return null; } Object obj = getBean(name.trim() + "Mapper"); if (!(obj instanceof GeomBaseMapper)) { return null; } return (GeomBaseMapper) obj; } /** * 获取类名 * * @param baseMapper 父Mapper src/main/java/com/lf/server/service/all/BaseQueryService.java
@@ -2,6 +2,7 @@ import com.baomidou.mybatisplus.annotation.TableName; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.lf.server.entity.all.RedisCacheKey; import com.lf.server.entity.ctrl.IdNameEntity; import com.lf.server.entity.ctrl.TabEntity; @@ -38,44 +39,6 @@ * 表名Map */ private static Map<String, String> tabMap = new HashMap<String, String>(3); /** * 获取父Mapper * * @param name Mapper名 * @return BaseMapper */ public BasicMapper getBasicMapper(String name) { if (StringHelper.isEmpty(name)) { return null; } Object obj = ClassHelper.getBean(name.trim() + "Mapper"); if (!(obj instanceof BasicMapper)) { return null; } return (BasicMapper) obj; } /** * 获取空间父Mapper * * @param name Mapper名 * @return GeomBaseMapper */ public GeomBaseMapper getGeoBaseMapper(String name) { if (StringHelper.isEmpty(name)) { return null; } Object obj = ClassHelper.getBean(name.trim() + "Mapper"); if (!(obj instanceof GeomBaseMapper)) { return null; } return (GeomBaseMapper) obj; } /** * 添加过滤条件 src/main/java/com/lf/server/service/data/DataLoaderService.java
@@ -1,8 +1,12 @@ package com.lf.server.service.data; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.lf.server.entity.ctrl.TabMapperEntity; import com.lf.server.entity.data.MetaEntity; import com.lf.server.entity.data.MetaFileEntity; import com.lf.server.entity.md.MdZxcgEntity; import com.lf.server.helper.ClassHelper; import com.lf.server.helper.ExcelHelper; import com.lf.server.helper.FileHelper; import com.lf.server.service.all.BaseUploadService; import org.springframework.beans.factory.annotation.Autowired; @@ -162,7 +166,7 @@ String root = pathHelper.getConfig().getUploadPath(); switch (me.getType()) { case "xls": return insertXls(root, mfe); return insertXls(root, mfe, tabs); case "mdb": return insertMdb(root, mfe, tabs); case "shp": @@ -177,7 +181,27 @@ /** * 插入Excel */ private Integer insertXls(String root, MetaFileEntity mfe) { private Integer insertXls(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { TabMapperEntity tab = getTabEntity(mfe, tabs); if (null == tab) { return 0; } BaseMapper baseMapper = ClassHelper.getBasicMapper(tab.getEntity()); if (null == baseMapper) { return 0; } String className = ClassHelper.getClassName(baseMapper); Class clazz = ClassHelper.getEntityClass(className); if (null == clazz) { return 0; } List<?> list = ExcelHelper.readExcel(clazz, root + File.separator + mfe.getPath()); if (null == list || list.isEmpty()) { return 0; } return 0; } @@ -205,4 +229,17 @@ return 0; } /** * 获取表映射实体类 */ private TabMapperEntity getTabEntity(MetaFileEntity mfe, List<TabMapperEntity> tabs) { for (TabMapperEntity tab : tabs) { if (tab.getFileName().equals(mfe.getName())) { return tab; } } return null; } }