| | |
| | | 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.*; |
| | | import com.lf.server.mapper.all.BasicMapper; |
| | | import com.lf.server.mapper.all.GeomBaseMapper; |
| | | import com.lf.server.service.all.BaseQueryService; |
| | | import com.lf.server.service.all.BaseUploadService; |
| | |
| | | /** |
| | | * 插入文件 |
| | | */ |
| | | public int insertFiles(MetaEntity entity, List<MetaFileEntity> list, List<TabMapperEntity> tabs) { |
| | | int count = 0; |
| | | public void insertFiles(MetaEntity entity, List<MetaFileEntity> list, List<TabMapperEntity> tabs) { |
| | | try { |
| | | String temp = pathHelper.getConfig().getTempPath(); |
| | | String root = pathHelper.getUploadFullPath(); |
| | | String full = pathHelper.getUploadFullPath(); |
| | | String root = pathHelper.getConfig().getUploadPath(); |
| | | |
| | | for (MetaFileEntity mf : list) { |
| | | String filePath = getFilePath(temp, root, mf); |
| | | String filePath = getFilePath(temp, full, mf); |
| | | if (null == filePath) { |
| | | continue; |
| | | } |
| | |
| | | } |
| | | |
| | | // 入库 |
| | | if (null != me.getType() && insertDb(me, mfe, tabs) > 0) { |
| | | count++; |
| | | switch (me.getType()) { |
| | | case "xls": |
| | | insertXls(root, mfe, tabs); |
| | | break; |
| | | case "shp": |
| | | insertShp(temp + "_zip", mfe, tabs); |
| | | break; |
| | | case "gdb": |
| | | insertGdb(temp + "_zip", mfe, tabs); |
| | | break; |
| | | case "mdb": |
| | | insertMdb(temp + "_zip", mfe, tabs); |
| | | break; |
| | | default: |
| | | break; |
| | | } |
| | | } |
| | | } catch (Exception ex) { |
| | | log.error(ex.getMessage(), ex); |
| | | } |
| | | |
| | | return count; |
| | | } |
| | | |
| | | /** |
| | |
| | | } |
| | | |
| | | /** |
| | | * 插入数据库 |
| | | */ |
| | | 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) { |
| | | private void insertXls(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | TabMapperEntity tab = getTabEntity(mfe, tabs); |
| | | if (null == tab) { |
| | | return 0; |
| | | if (null == tab|| StringHelper.isEmpty(tab.getEntity())) { |
| | | return; |
| | | } |
| | | |
| | | BaseMapper baseMapper = ClassHelper.getBasicMapper(tab.getEntity()); |
| | | if (null == baseMapper) { |
| | | return 0; |
| | | BasicMapper basicMapper = ClassHelper.getBasicMapper(tab.getEntity()); |
| | | if (null == basicMapper) { |
| | | return; |
| | | } |
| | | |
| | | String className = ClassHelper.getClassName(baseMapper); |
| | | String className = ClassHelper.getClassName(basicMapper); |
| | | Class clazz = ClassHelper.getEntityClass(className); |
| | | if (null == clazz) { |
| | | return 0; |
| | | return; |
| | | } |
| | | |
| | | List<?> list = ExcelHelper.readExcel(clazz, root + File.separator + mfe.getPath()); |
| | | if (null == list || list.isEmpty()) { |
| | | return 0; |
| | | return; |
| | | } |
| | | |
| | | setCreateInfo(list, mfe); |
| | | |
| | | int rows = 0; |
| | | for (int i = 0, c = list.size(); i < c; i++) { |
| | | rows += baseMapper.insert(list.get(i)); |
| | | rows += basicMapper.insert(list.get(i)); |
| | | } |
| | | if (basicMapper instanceof GeomBaseMapper) { |
| | | GeomBaseMapper geomBaseMapper = (GeomBaseMapper) basicMapper; |
| | | updateXlsGeom(geomBaseMapper, list); |
| | | } |
| | | |
| | | if (baseMapper instanceof GeomBaseMapper) { |
| | | GeomBaseMapper geomBaseMapper = (GeomBaseMapper) baseMapper; |
| | | updateGeom(geomBaseMapper, list); |
| | | tab.setRows(rows); |
| | | } |
| | | |
| | | /** |
| | | * 获取表映射实体类 |
| | | */ |
| | | private TabMapperEntity getTabEntity(MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | for (TabMapperEntity tab : tabs) { |
| | | if (tab.getFileName().equals(mfe.getName())) { |
| | | return tab; |
| | | } |
| | | } |
| | | |
| | | return rows; |
| | | return null; |
| | | } |
| | | |
| | | /** |
| | | * 设置创建信息 |
| | | */ |
| | | @SuppressWarnings("AlibabaRemoveCommentedCode") |
| | | private <T> void setCreateInfo(List<T> list, MetaFileEntity mfe) { |
| | | try { |
| | | for (T t : list) { |
| | |
| | | /** |
| | | * 设置空间信息 |
| | | */ |
| | | private <T> void updateGeom(GeomBaseMapper geomBaseMapper, List<T> list) { |
| | | private <T> void updateXlsGeom(GeomBaseMapper geomBaseMapper, List<T> list) { |
| | | try { |
| | | String tabName = BaseQueryService.getTabName(geomBaseMapper); |
| | | for (T t : list) { |
| | |
| | | } |
| | | |
| | | /** |
| | | * 插入MDB |
| | | * 插入SHP |
| | | */ |
| | | private Integer insertMdb(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | private void insertShp(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | for (TabMapperEntity tab : tabs) { |
| | | if (!tab.getFileName().equals(mfe.getName()) || StringHelper.isEmpty(tab.getEntity())) { |
| | | continue; |
| | | } |
| | | |
| | | return 0; |
| | | BasicMapper basicMapper = ClassHelper.getBasicMapper(tab.getEntity()); |
| | | if (null == basicMapper) { |
| | | continue; |
| | | } |
| | | |
| | | String className = ClassHelper.getClassName(basicMapper); |
| | | Class clazz = ClassHelper.getEntityClass(className); |
| | | if (null == clazz) { |
| | | continue; |
| | | } |
| | | |
| | | List<?> list = ShpHelper.readData(clazz, root + File.separator + tab.getSubPath()); |
| | | if (null == list || list.isEmpty()) { |
| | | continue; |
| | | } |
| | | setCreateInfo(list, mfe); |
| | | |
| | | Integer rows = basicMapper.insertBatch(list); |
| | | if (basicMapper instanceof GeomBaseMapper) { |
| | | GeomBaseMapper geomBaseMapper = (GeomBaseMapper) basicMapper; |
| | | updateXlsGeom(geomBaseMapper, list); |
| | | } |
| | | |
| | | tab.setRows(rows); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 插入SHP |
| | | * 设置空间信息 |
| | | */ |
| | | private Integer insertShp(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | private <T> void updateDbGeom(GeomBaseMapper geomBaseMapper, List<T> list) { |
| | | try { |
| | | String tabName = BaseQueryService.getTabName(geomBaseMapper); |
| | | for (T t : list) { |
| | | BaseEntity baseEntity = (BaseEntity) t; |
| | | Integer gid = baseEntity.getGid(); |
| | | |
| | | return 0; |
| | | Field gField = t.getClass().getDeclaredField("geom"); |
| | | gField.setAccessible(true); |
| | | Object obj = gField.get(t); |
| | | |
| | | if (null != obj) { |
| | | geomBaseMapper.updateGeom(tabName, gid, (String) obj); |
| | | } |
| | | } |
| | | } catch (Exception ex) { |
| | | log.error(ex.getMessage(), ex); |
| | | } |
| | | } |
| | | |
| | | /** |
| | |
| | | } |
| | | |
| | | /** |
| | | * 获取表映射实体类 |
| | | * 插入MDB |
| | | */ |
| | | private TabMapperEntity getTabEntity(MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | for (TabMapperEntity tab : tabs) { |
| | | if (tab.getFileName().equals(mfe.getName())) { |
| | | return tab; |
| | | } |
| | | } |
| | | private Integer insertMdb(String root, MetaFileEntity mfe, List<TabMapperEntity> tabs) { |
| | | |
| | | return null; |
| | | return 0; |
| | | } |
| | | } |