| | |
| | | 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; |
| | |
| | | @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<MetaFileEntity> list) { |
| | | public int insertFiles(MetaEntity entity, List<MetaFileEntity> list, List<TabMapperEntity> tabs) { |
| | | int count = 0; |
| | | try { |
| | | String temp = pathHelper.getConfig().getTempPath(); |
| | | String root = pathHelper.getUploadFullPath(); |
| | | String uploadPath = pathHelper.getConfig().getUploadPath(); |
| | | |
| | | for (MetaFileEntity mf : list) { |
| | | String filePath = getFilePath(temp, root, mf); |
| | |
| | | |
| | | // 元数据 |
| | | MetaEntity me = createMetaEntity(entity, mf); |
| | | Integer rows = metaService.insert(me); |
| | | if (rows < 1) { |
| | | if (metaService.insert(me) < 1) { |
| | | continue; |
| | | } |
| | | |
| | | // 元数据文件 |
| | | MetaFileEntity mfe = createMetaFileEntity(entity, mf, filePath); |
| | | rows = metaFileService.insert(mfe); |
| | | if (rows < 1) { |
| | | if (metaFileService.insert(mfe) < 1) { |
| | | continue; |
| | | } |
| | | |
| | | rows = insertDb(mfe, uploadPath); |
| | | if (rows > 0) { |
| | | // 入库 |
| | | if (null != me.getType() && insertDb(me, mfe, tabs) > 0) { |
| | | count++; |
| | | } |
| | | } |
| | |
| | | me.setDepid(entity.getDepid()); |
| | | me.setDirid(entity.getDirid()); |
| | | me.setVerid(entity.getVerid()); |
| | | me.setType(getType(entity.getName().toLowerCase())); |
| | | me.setType(getType(mf.getName().toLowerCase())); |
| | | me.setGather(entity.getGather()); |
| | | me.setBatch(entity.getBatch()); |
| | | me.setDescr(entity.getDescr()); |
| | |
| | | * 获取文件类型 |
| | | */ |
| | | private String getType(String name) { |
| | | if (name.contains(".xls")) { |
| | | if (name.contains(XLS)) { |
| | | return "xls"; |
| | | } |
| | | if (name.contains(".mdb")) { |
| | | if (name.contains(MDB)) { |
| | | return "mdb"; |
| | | } |
| | | if (name.contains(".shp")) { |
| | | if (name.contains(SHP)) { |
| | | return "shp"; |
| | | } |
| | | if (name.contains(".gdb")) { |
| | | if (name.contains(GDB)) { |
| | | return "gdb"; |
| | | } |
| | | |
| | |
| | | /** |
| | | * 插入数据库 |
| | | */ |
| | | private Integer insertDb(MetaFileEntity mfe, String root) { |
| | | private Integer insertDb(MetaEntity me, MetaFileEntity mfe, List<TabMapperEntity> 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<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; |
| | | } |
| | | |
| | | /** |
| | | * 插入MDB |
| | | */ |
| | | private Integer insertMdb(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | /** |
| | | * 插入SHP |
| | | */ |
| | | private Integer insertShp(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | /** |
| | | * 插入GDB |
| | | */ |
| | | private Integer insertGdb(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | /** |
| | | * 获取表映射实体类 |
| | | */ |
| | | private TabMapperEntity getTabEntity(MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | for (TabMapperEntity tab : tabs) { |
| | | if (tab.getFileName().equals(mfe.getName())) { |
| | | return tab; |
| | | } |
| | | } |
| | | |
| | | return null; |
| | | } |
| | | } |