fix: fix dm get Sequence
This commit is contained in:
		| @@ -44,7 +44,7 @@ public interface TableMapper { | ||||
|     Object getSequence(@Param("tableName") String tableName); | ||||
|     Object getHighGoSequence(@Param("tableName") String tableName); | ||||
|     boolean judgeHighGoSequenceExist(@Param("tableName") String tableName); | ||||
|     boolean judgeDamengSequenceExist(@Param("tableName") String tableName); | ||||
|     int judgeDamengSequenceExist(@Param("tableName") String tableName,@Param("schema")String schema); | ||||
|     int createSequence(@Param("tableName") String tableName, @Param("lastId")Object lastId); | ||||
|     int createHighGoSequence(@Param("tableName") String tableName, @Param("lastId")Object lastId); | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| package com.taixingyiji.base.module.data.module; | ||||
|  | ||||
| import com.alibaba.druid.pool.DruidDataSource; | ||||
| import com.github.pagehelper.PageInfo; | ||||
| import com.taixingyiji.base.common.ServiceException; | ||||
| import com.taixingyiji.base.common.WebPageInfo; | ||||
| @@ -17,6 +18,7 @@ import org.mybatis.spring.SqlSessionTemplate; | ||||
| import org.springframework.beans.factory.annotation.Value; | ||||
| import org.springframework.stereotype.Service; | ||||
|  | ||||
| import java.sql.Connection; | ||||
| import java.util.Collections; | ||||
| import java.util.HashMap; | ||||
| import java.util.List; | ||||
| @@ -28,14 +30,17 @@ public class BaseMapperImpl implements BaseMapper { | ||||
|     public static final String BASE = "base"; | ||||
|     public static final String TABLE_MAPPER_PACKAGE = "com.taixingyiji.base.module.data.dao.TableMapper."; | ||||
|     final TableMapper tableMapper; | ||||
|     final DruidDataSource druidDataSource; | ||||
|  | ||||
|     @Value("${spring.datasource.druid.driver-class-name}") | ||||
|     public String dataType; | ||||
|     final SqlSessionTemplate sqlSessionTemplate; | ||||
|  | ||||
|     public BaseMapperImpl(TableMapper tableMapper, SqlSessionTemplate sqlSessionTemplate) { | ||||
|     public BaseMapperImpl(TableMapper tableMapper, SqlSessionTemplate sqlSessionTemplate, | ||||
|                           DruidDataSource druidDataSource) { | ||||
|         this.tableMapper = tableMapper; | ||||
|         this.sqlSessionTemplate = sqlSessionTemplate; | ||||
|         this.druidDataSource = druidDataSource; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
| @@ -43,9 +48,29 @@ public class BaseMapperImpl implements BaseMapper { | ||||
|         String key; | ||||
|         DatasourceConfig datasourceConfig = new DatasourceConfig(); | ||||
|         try { | ||||
|  | ||||
|             key = DBContextHolder.getDataSource(); | ||||
|             datasourceConfig = DataSourceUtil.get(key); | ||||
|         } catch (Exception e) { | ||||
|             try { | ||||
|                 Connection connection = druidDataSource.getConnection(); | ||||
|                 String dbType = connection.getMetaData().getDatabaseProductName(); | ||||
|                 if (dbType.contains("Oracle")) { | ||||
|                     datasourceConfig.setCommonType(DataUnit.ORACLE); | ||||
|                 } | ||||
|                 if (dbType.contains("MySQL")) { | ||||
|                     datasourceConfig.setCommonType(DataUnit.MYSQL); | ||||
|                 } | ||||
|                 if (dbType.contains("DM")) { | ||||
|                     datasourceConfig.setCommonType(DataUnit.DAMENG); | ||||
|                 } | ||||
|                 if (dbType.contains("SQLite")) { | ||||
|                     datasourceConfig.setCommonType(DataUnit.SQLITE); | ||||
|                 } | ||||
|                 if (dbType.contains("PostgreSQL")) { | ||||
|                     datasourceConfig.setCommonType(DataUnit.HANGO); | ||||
|                 } | ||||
|             } catch (Exception e1) { | ||||
|                 if (dataType.contains("oracle")) { | ||||
|                     datasourceConfig.setCommonType(DataUnit.ORACLE); | ||||
|                 } | ||||
| @@ -62,6 +87,7 @@ public class BaseMapperImpl implements BaseMapper { | ||||
|                     datasourceConfig.setCommonType(DataUnit.HANGO); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return datasourceConfig.getCommonType(); | ||||
|     } | ||||
|  | ||||
| @@ -800,10 +826,7 @@ public class BaseMapperImpl implements BaseMapper { | ||||
|         Object id; | ||||
|         if (DataUnit.HANGO.equals(dataTypeConfig)) { | ||||
|             if (!tableMapper.judgeHighGoSequenceExist(tableName.toLowerCase())) { | ||||
|                 MyPageHelper.noCount(WebPageInfo.builder().pageNum(1).pageSize(1).order(WebPageInfo.DESC).sortField(pkName).build()); | ||||
|                 DataMap<Object> dataMap = DataMap.builder().tableName(tableName).pkName(pkName).fields(pkName).build(); | ||||
|                 Condition condition = Condition.creatCriteria(dataMap).build(); | ||||
|                 Map<String, Object> map = selectOneByCondition(condition); | ||||
|                 Map<String, Object> map = selectRecentData(tableName, pkName); | ||||
|                 if (map == null) { | ||||
|                     tableMapper.createHighGoSequence(tableName, 1); | ||||
|                 } else { | ||||
| @@ -813,12 +836,15 @@ public class BaseMapperImpl implements BaseMapper { | ||||
|             id = tableMapper.getHighGoSequence(tableName); | ||||
|         } else { | ||||
|             try { | ||||
|                 String url = druidDataSource.getUrl(); | ||||
|                 String schema = getSchemaFromJdbcUrl(url); | ||||
|                 if(tableMapper.judgeDamengSequenceExist(tableName,schema)>0) { | ||||
|                     id = tableMapper.getSequence(tableName); | ||||
|                 }else { | ||||
|                     throw new ServiceException("序列不存在"); | ||||
|                 } | ||||
|             } catch (Exception e) { | ||||
|                 MyPageHelper.noCount(WebPageInfo.builder().pageNum(1).pageSize(1).order(WebPageInfo.DESC).sortField(pkName).build()); | ||||
|                 DataMap<Object> dataMap = DataMap.builder().tableName(tableName).pkName(pkName).fields(pkName).build(); | ||||
|                 Condition condition = Condition.creatCriteria(dataMap).build(); | ||||
|                 Map<String, Object> map = selectOneByCondition(condition); | ||||
|                 Map<String, Object> map = selectRecentData(tableName, pkName); | ||||
|                 if (map == null) { | ||||
|                     tableMapper.createSequence(tableName, 1); | ||||
|                 } else { | ||||
| @@ -829,4 +855,31 @@ public class BaseMapperImpl implements BaseMapper { | ||||
|         } | ||||
|         return Long.parseLong(id.toString()) + 1L; | ||||
|     } | ||||
|  | ||||
|     private Map<String, Object> selectRecentData(String tableName, String pkName) { | ||||
|         MyPageHelper.noCount(WebPageInfo.builder().pageNum(1).pageSize(1).order(WebPageInfo.DESC).sortField(pkName).build()); | ||||
|         DataMap<Object> dataMap = DataMap.builder().tableName(tableName).pkName(pkName).fields(pkName).build(); | ||||
|         Condition condition = Condition.creatCriteria(dataMap).build(); | ||||
|         return selectOneByCondition(condition); | ||||
|     } | ||||
|  | ||||
|     public static String getSchemaFromJdbcUrl(String url) { | ||||
|         if (url == null || !url.contains("?")) { | ||||
|             return null; | ||||
|         } | ||||
|  | ||||
|         String[] parts = url.split("\\?"); | ||||
|         if (parts.length < 2) { | ||||
|             return null; | ||||
|         } | ||||
|  | ||||
|         String[] params = parts[1].split("&"); | ||||
|         for (String param : params) { | ||||
|             if (param.toLowerCase().startsWith("schema=")) { | ||||
|                 return param.substring("schema=".length()); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -187,10 +187,11 @@ | ||||
|               AND pg_table_is_visible(oid) | ||||
|         ); | ||||
|     </select> | ||||
|     <select id="judgeDamengSequenceExist" resultType="boolean"> | ||||
|     <select id="judgeDamengSequenceExist" resultType="int"> | ||||
|         SELECT COUNT(*) | ||||
|         FROM SYSOBJECTS | ||||
|         WHERE NAME = '${tableName}_seq' AND SUBTYPE$ = 'SEQUENCE'; | ||||
|         FROM all_sequences | ||||
|         WHERE sequence_owner = '${schema}' | ||||
|           AND sequence_name = '${tableName}_SEQ' | ||||
|     </select> | ||||
|     <select id="count" resultType="java.lang.Long"> | ||||
|         SELECT count(0) FROM ${tableName} ${sql} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user