package com.iailab.module.infra.service.db;
|
|
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.lang.Assert;
|
import cn.hutool.core.util.StrUtil;
|
import com.iailab.framework.mybatis.core.util.JdbcUtils;
|
import com.iailab.module.infra.dal.dataobject.db.DataSourceConfigDO;
|
import com.baomidou.mybatisplus.annotation.DbType;
|
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
|
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
|
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
|
import com.baomidou.mybatisplus.generator.config.builder.ConfigBuilder;
|
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
|
import com.baomidou.mybatisplus.generator.config.rules.DateType;
|
import com.baomidou.mybatisplus.generator.query.SQLQuery;
|
import org.springframework.stereotype.Service;
|
|
import javax.annotation.Resource;
|
import java.util.Comparator;
|
import java.util.List;
|
import java.util.Objects;
|
import java.util.stream.Collectors;
|
|
/**
|
* 数据库表 Service 实现类
|
*
|
* @author iailab
|
*/
|
@Service
|
public class DatabaseTableServiceImpl implements DatabaseTableService {
|
|
@Resource
|
private DataSourceConfigService dataSourceConfigService;
|
|
@Override
|
public List<TableInfo> getTableList(Long dataSourceConfigId, String nameLike, String commentLike) {
|
List<TableInfo> tables = getTableList0(dataSourceConfigId, null);
|
return tables.stream().filter(tableInfo -> (StrUtil.isEmpty(nameLike) || tableInfo.getName().contains(nameLike))
|
&& (StrUtil.isEmpty(commentLike) || tableInfo.getComment().contains(commentLike)))
|
.collect(Collectors.toList());
|
}
|
|
@Override
|
public TableInfo getTable(Long dataSourceConfigId, String name) {
|
return CollUtil.getFirst(getTableList0(dataSourceConfigId, name));
|
}
|
|
private List<TableInfo> getTableList0(Long dataSourceConfigId, String name) {
|
// 获得数据源配置
|
DataSourceConfigDO config = dataSourceConfigService.getDataSourceConfig(dataSourceConfigId);
|
Assert.notNull(config, "数据源({}) 不存在!", dataSourceConfigId);
|
DbType dbType = JdbcUtils.getDbType(config.getUrl());
|
|
// 使用 MyBatis Plus Generator 解析表结构
|
DataSourceConfig.Builder dataSourceConfigBuilder = new DataSourceConfig.Builder(config.getUrl(), config.getUsername(),
|
config.getPassword());
|
if (Objects.equals(dbType, DbType.SQL_SERVER)) { // 特殊:SQLServer jdbc 非标准,参见 https://github.com/baomidou/mybatis-plus/issues/5419
|
dataSourceConfigBuilder.databaseQueryClass(SQLQuery.class);
|
}
|
StrategyConfig.Builder strategyConfig = new StrategyConfig.Builder().enableSkipView(); // 忽略视图,业务上一般用不到
|
if (StrUtil.isNotEmpty(name)) {
|
strategyConfig.addInclude(name);
|
} else {
|
// 移除工作流和定时任务前缀的表名
|
strategyConfig.addExclude("ACT_[\\S\\s]+|QRTZ_[\\S\\s]+|FLW_[\\S\\s]+");
|
// 移除 ORACLE 相关的系统表
|
strategyConfig.addExclude("IMPDP_[\\S\\s]+|ALL_[\\S\\s]+|HS_[\\S\\\\s]+");
|
strategyConfig.addExclude("[\\S\\s]+\\$[\\S\\s]+|[\\S\\s]+\\$"); // 表里不能有 $,一般有都是系统的表
|
}
|
|
GlobalConfig globalConfig = new GlobalConfig.Builder().dateType(DateType.TIME_PACK).build(); // 只使用 LocalDateTime 类型,不使用 LocalDate
|
ConfigBuilder builder = new ConfigBuilder(null, dataSourceConfigBuilder.build(), strategyConfig.build(),
|
null, globalConfig, null);
|
// 按照名字排序
|
List<TableInfo> tables = builder.getTableInfoList();
|
tables.sort(Comparator.comparing(TableInfo::getName));
|
return tables;
|
}
|
|
}
|