package com.lf.server.service.data; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.lf.server.entity.all.BaseEntity; 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.helper.ClassHelper; import com.lf.server.helper.ExcelHelper; import com.lf.server.helper.FileHelper; import com.lf.server.mapper.all.GeomBaseMapper; import com.lf.server.service.all.BaseQueryService; import com.lf.server.service.all.BaseUploadService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.io.File; import java.lang.reflect.Field; import java.util.List; /** * 数据入库 * @author WWW */ @Service public class DataLoaderService extends BaseUploadService { @Autowired MetaService metaService; @Autowired MetaFileService metaFileService; private final static String XLS = ".xls"; private final static String MDB = ".mdb"; private final static String SHP = ".shp"; private final static String GDB = ".gdb"; /** * 插入文件 */ public int insertFiles(MetaEntity entity, List list, List tabs) { int count = 0; try { String temp = pathHelper.getConfig().getTempPath(); String root = pathHelper.getUploadFullPath(); for (MetaFileEntity mf : list) { String filePath = getFilePath(temp, root, mf); if (null == filePath) { continue; } // 元数据 MetaEntity me = createMetaEntity(entity, mf); if (metaService.insert(me) < 1) { continue; } // 元数据文件 MetaFileEntity mfe = createMetaFileEntity(me, mf, filePath); if (metaFileService.insert(mfe) < 1) { continue; } // 入库 if (null != me.getType() && insertDb(me, mfe, tabs) > 0) { count++; } } } catch (Exception ex) { log.error(ex.getMessage(), ex); } return count; } /** * 获取文件路径 */ private String getFilePath(String temp, String root, MetaFileEntity mf) { // 移动文件 File file = new File(temp + File.separator + mf.getPath()); File newFile = new File(root + File.separator + mf.getGuid()); // 文件类型 String metaType = getType(mf.getName().toLowerCase()); if (null == metaType) { file.delete(); return null; } MetaFileEntity old = metaFileService.selectByGuid(mf.getGuid()); String filePath = null; if (null == old) { filePath = newFile.getPath(); file.renameTo(newFile); } else { filePath = old.getPath(); file.delete(); } return filePath; } /** * 创建元数据实体 */ private MetaEntity createMetaEntity(MetaEntity entity, MetaFileEntity mf) { MetaEntity me = new MetaEntity(); me.setDepid(entity.getDepid()); me.setDirid(entity.getDirid()); me.setVerid(entity.getVerid()); me.setType(getType(mf.getName().toLowerCase())); me.setGather(entity.getGather()); me.setBatch(entity.getBatch()); me.setDescr(entity.getDescr()); me.setName(mf.getName()); me.setSizes(mf.getSizes()); me.setCreateTime(entity.getCreateTime()); me.setCreateUser(entity.getCreateUser()); return me; } /** * 创建元数据文件实体 */ private MetaFileEntity createMetaFileEntity(MetaEntity me, MetaFileEntity entity, String filePath) { MetaFileEntity mfe = new MetaFileEntity(); mfe.setName(entity.getName()); mfe.setMetaid(me.getId()); mfe.setGuid(entity.getGuid()); mfe.setSizes(entity.getSizes()); mfe.setPath(FileHelper.getRelativePath(filePath)); mfe.setCreateUser(me.getCreateUser()); mfe.setCreateTime(me.getCreateTime()); return mfe; } /** * 获取文件类型 */ private String getType(String name) { if (name.contains(XLS)) { return "xls"; } if (name.contains(MDB)) { return "mdb"; } if (name.contains(SHP)) { return "shp"; } if (name.contains(GDB)) { return "gdb"; } return null; } /** * 插入数据库 */ private Integer insertDb(MetaEntity me, MetaFileEntity mfe, List tabs) { String root = pathHelper.getConfig().getUploadPath(); switch (me.getType()) { case "xls": return insertXls(root, mfe, tabs); case "mdb": return insertMdb(root, mfe, tabs); case "shp": return insertShp(root, mfe, tabs); case "gdb": return insertGdb(root, mfe, tabs); default: return 0; } } /** * 插入Excel */ private Integer insertXls(String root, MetaFileEntity mfe, List 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; } setCreateInfo(list, mfe); int rows = 0; for (int i = 0, c = list.size(); i < c; i++) { rows += baseMapper.insert(list.get(i)); } if (baseMapper instanceof GeomBaseMapper) { GeomBaseMapper geomBaseMapper = (GeomBaseMapper) baseMapper; updateGeom(geomBaseMapper, list); } return rows; } /** * 设置创建信息 */ @SuppressWarnings("AlibabaRemoveCommentedCode") private void setCreateInfo(List list, MetaFileEntity mfe) { try { for (T t : list) { Field cuField = t.getClass().getDeclaredField("createuser"); cuField.setAccessible(true); cuField.set(t, mfe.getCreateUser()); Field ctField = t.getClass().getDeclaredField("createtime"); ctField.setAccessible(true); ctField.set(t, mfe.getCreateTime()); } } catch (Exception ex) { log.error(ex.getMessage(), ex); } } /** * 设置空间信息 */ private void updateGeom(GeomBaseMapper geomBaseMapper, List list) { try { String tabName = BaseQueryService.getTabName(geomBaseMapper); for (T t : list) { Field xField = t.getClass().getDeclaredField("x"); xField.setAccessible(true); double x = (double) xField.get(t); Field yField = t.getClass().getDeclaredField("y"); yField.setAccessible(true); double y = (double) yField.get(t); BaseEntity baseEntity = (BaseEntity) t; Integer gid = baseEntity.getGid(); String wkt = String.format("POINT(%f %f)", x, y); geomBaseMapper.updateGeom(tabName, gid, wkt); } } catch (Exception ex) { log.error(ex.getMessage(), ex); } } /** * 插入MDB */ private Integer insertMdb(String root, MetaFileEntity mfe, List tabs) { return 0; } /** * 插入SHP */ private Integer insertShp(String root, MetaFileEntity mfe, List tabs) { return 0; } /** * 插入GDB */ private Integer insertGdb(String root, MetaFileEntity mfe, List tabs) { return 0; } /** * 获取表映射实体类 */ private TabMapperEntity getTabEntity(MetaFileEntity mfe, List tabs) { for (TabMapperEntity tab : tabs) { if (tab.getFileName().equals(mfe.getName())) { return tab; } } return null; } }