wip: 代码生成临时提交

This commit is contained in:
Ray.Hao
2024-07-26 23:05:33 +08:00
parent bf0e898752
commit 41917686b1
6 changed files with 79 additions and 53 deletions

View File

@@ -17,6 +17,12 @@ import org.springframework.web.bind.annotation.*;
import java.util.List; import java.util.List;
/**
* 代码生成器控制层
*
* @author Ray
* @since 2.10.0
*/
@Tag(name = "09.代码生成") @Tag(name = "09.代码生成")
@RestController @RestController
@RequestMapping("/api/v1/generator") @RequestMapping("/api/v1/generator")

View File

@@ -18,7 +18,7 @@ import java.util.List;
public interface GenConfigConverter { public interface GenConfigConverter {
@Mapping(source = "genConfig.tableName", target = "tableName") @Mapping(source = "genConfig.tableName", target = "tableName")
@Mapping(source = "genConfig.comment", target = "comment") @Mapping(source = "genConfig.businessName", target = "businessName")
@Mapping(source = "genConfig.moduleName", target = "moduleName") @Mapping(source = "genConfig.moduleName", target = "moduleName")
@Mapping(source = "genConfig.packageName", target = "packageName") @Mapping(source = "genConfig.packageName", target = "packageName")
@Mapping(source = "genConfig.entityName", target = "entityName") @Mapping(source = "genConfig.entityName", target = "entityName")
@@ -31,14 +31,10 @@ public interface GenConfigConverter {
GenConfigForm.FieldConfig toGenFieldConfigForm(GenFieldConfig genFieldConfig); GenConfigForm.FieldConfig toGenFieldConfigForm(GenFieldConfig genFieldConfig);
GenConfig toGenConfig(GenConfigForm formData);
@Mapping(source = "formData", target = "genConfig") List<GenFieldConfig> toGenFieldConfig(List<GenConfigForm.FieldConfig> fieldConfigs);
@Mapping(source = "formData.fieldConfigs", target = "fieldConfigs")
GenConfig toGenConfigEntity(GenConfigForm formData);
@Mapping(source = "formData.fieldConfigs", target = "fieldConfigs") GenFieldConfig toGenFieldConfig(GenConfigForm.FieldConfig fieldConfig);
List<GenFieldConfig> toGenFieldConfigEntity(List<GenConfigForm.FieldConfig> fieldConfigs);
GenFieldConfig toGenFieldConfigEntity(GenConfigForm.FieldConfig fieldConfig);
} }

View File

@@ -1,6 +1,8 @@
package com.youlai.system.enums; package com.youlai.system.enums;
import com.baomidou.mybatisplus.annotation.EnumValue; import com.baomidou.mybatisplus.annotation.EnumValue;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonValue;
import com.youlai.system.common.base.IBaseEnum; import com.youlai.system.common.base.IBaseEnum;
import lombok.Getter; import lombok.Getter;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
@@ -63,8 +65,20 @@ public enum FormTypeEnum implements IBaseEnum<Integer> {
// Mybatis-Plus 提供注解表示插入数据库时插入该值 // Mybatis-Plus 提供注解表示插入数据库时插入该值
@EnumValue @EnumValue
@JsonValue
private final Integer value; private final Integer value;
// @JsonValue // 表示对枚举序列化时返回此字段 // @JsonValue // 表示对枚举序列化时返回此字段
private final String label; private final String label;
@JsonCreator
public static QueryTypeEnum fromValue(Integer value) {
for (QueryTypeEnum type : QueryTypeEnum.values()) {
if (type.getValue().equals(value)) {
return type;
}
}
throw new IllegalArgumentException("No enum constant with value " + value);
}
} }

View File

@@ -19,6 +19,7 @@ import lombok.Setter;
@Setter @Setter
public class GenFieldConfig extends BaseEntity { public class GenFieldConfig extends BaseEntity {
/** /**
* 关联的配置ID * 关联的配置ID
*/ */

View File

@@ -7,29 +7,35 @@ import lombok.Data;
import java.util.List; import java.util.List;
/**
* 代码生成配置表单
*
* @author Ray
* @since 2.10.0
*/
@Schema(description = "代码生成配置表单") @Schema(description = "代码生成配置表单")
@Data @Data
public class GenConfigForm { public class GenConfigForm {
@Schema(description = "主键") @Schema(description = "主键",example = "1")
private Long id; private Long id;
@Schema(description = "表名") @Schema(description = "表名",example = "sys_user")
private String tableName; private String tableName;
@Schema(description = "类描述") @Schema(description = "业务名",example = "用户")
private String comment; private String businessName;
@Schema(description = "模块名") @Schema(description = "模块名",example = "system")
private String moduleName; private String moduleName;
@Schema(description = "包名") @Schema(description = "包名",example = "com.youlai.system")
private String packageName; private String packageName;
@Schema(description = "实体名") @Schema(description = "实体名",example = "User")
private String entityName; private String entityName;
@Schema(description = "作者") @Schema(description = "作者",example = "youlaitech")
private String author; private String author;
@Schema(description = "字段配置列表") @Schema(description = "字段配置列表")
@@ -39,6 +45,9 @@ public class GenConfigForm {
@Data @Data
public static class FieldConfig { public static class FieldConfig {
@Schema(description = "主键")
private Long id;
@Schema(description = "列名") @Schema(description = "列名")
private String columnName; private String columnName;

View File

@@ -14,15 +14,13 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.youlai.system.SystemApplication; import com.youlai.system.SystemApplication;
import com.youlai.system.config.property.GeneratorProperties; import com.youlai.system.config.property.GeneratorProperties;
import com.youlai.system.converter.GenConfigConverter; import com.youlai.system.converter.GenConfigConverter;
import com.youlai.system.enums.FormTypeEnum;
import com.youlai.system.enums.QueryTypeEnum;
import com.youlai.system.exception.BusinessException; import com.youlai.system.exception.BusinessException;
import com.youlai.system.mapper.DatabaseMapper; import com.youlai.system.mapper.DatabaseMapper;
import com.youlai.system.model.bo.ColumnMetaData;
import com.youlai.system.model.bo.TableMetaData;
import com.youlai.system.model.entity.GenConfig;
import com.youlai.system.model.entity.GenFieldConfig; import com.youlai.system.model.entity.GenFieldConfig;
import com.youlai.system.model.form.GenConfigForm; import com.youlai.system.model.form.GenConfigForm;
import com.youlai.system.model.query.TablePageQuery; import com.youlai.system.model.query.TablePageQuery;
import com.youlai.system.model.vo.GeneratorPreviewVO;
import com.youlai.system.service.GeneratorService; import com.youlai.system.service.GeneratorService;
import com.youlai.system.service.GenConfigService; import com.youlai.system.service.GenConfigService;
import com.youlai.system.service.GenFieldConfigService; import com.youlai.system.service.GenFieldConfigService;
@@ -84,7 +82,6 @@ public class GeneratorServiceImpl implements GeneratorService {
TableMetaData tableMetadata = databaseMapper.getTableMetadata(tableName); TableMetaData tableMetadata = databaseMapper.getTableMetadata(tableName);
Assert.isTrue(tableMetadata != null, "未找到表元数据"); Assert.isTrue(tableMetadata != null, "未找到表元数据");
genConfig = new GenConfig(); genConfig = new GenConfig();
genConfig.setTableName(tableName); genConfig.setTableName(tableName);
@@ -101,51 +98,54 @@ public class GeneratorServiceImpl implements GeneratorService {
} }
// 根据表的列 + 已经存在的字段生成配置 得到 组合后的字段生成配置
List<GenFieldConfig> genFieldConfigs = new ArrayList<>();
List<GenFieldConfig> genFieldConfigs = null; // 获取表的列
// 获取表的列信息
List<ColumnMetaData> tableColumns = databaseMapper.getTableColumns(tableName); List<ColumnMetaData> tableColumns = databaseMapper.getTableColumns(tableName);
if (CollectionUtil.isNotEmpty(tableColumns)) { if (CollectionUtil.isNotEmpty(tableColumns)) {
// 查询字段生成配置 // 查询字段生成配置
List<GenFieldConfig> configList = genFieldConfigService.list( List<GenFieldConfig> fieldConfigList = genFieldConfigService.list(
new LambdaQueryWrapper<>(GenFieldConfig.class) new LambdaQueryWrapper<>(GenFieldConfig.class)
.eq(GenFieldConfig::getConfigId, genConfig.getId()) .eq(GenFieldConfig::getConfigId, genConfig.getId())
); );
genFieldConfigs = new ArrayList<>();
for (ColumnMetaData tableColumn : tableColumns) { for (ColumnMetaData tableColumn : tableColumns) {
// 根据列名获取字段生成配置
String columnName = tableColumn.getColumnName();
GenFieldConfig genFieldConfig = fieldConfigList.stream()
.filter(item -> StrUtil.equals(item.getColumnName(), columnName))
.findFirst().orElseGet(() -> {
GenFieldConfig fieldConfig = new GenFieldConfig(); GenFieldConfig fieldConfig = new GenFieldConfig();
fieldConfig.setFieldName(tableColumn.getColumnName()); fieldConfig.setColumnName(tableColumn.getColumnName());
fieldConfig.setFieldType(tableColumn.getDataType()); fieldConfig.setColumnType(tableColumn.getDataType());
fieldConfig.setComment(tableColumn.getColumnComment()); fieldConfig.setComment(tableColumn.getColumnComment());
fieldConfig.setFieldName(StrUtil.toCamelCase(columnName));
fieldConfig.setFieldType(StrUtil.toCamelCase(tableColumn.getDataType()));
fieldConfig.setIsRequired("YES".equals(tableColumn.getIsNullable()) ? 1 : 0);
fieldConfig.setFormType(FormTypeEnum.INPUT);
fieldConfig.setQueryType(QueryTypeEnum.EQ);
return fieldConfig;
});
// 如果没有字段生成配置,则根据表的元数据生成默认配置 genFieldConfigs.add(genFieldConfig);
if (CollectionUtil.isNotEmpty(configList)) {
for (GenFieldConfig config : configList) {
if (StrUtil.equals(config.getFieldName(), fieldConfig.getFieldName())) {
fieldConfig = config;
break;
} }
} }
}
genFieldConfigs.add(fieldConfig);
}
}
GenConfigForm configFormData = genConfigConverter.toGenConfigForm(genConfig, genFieldConfigs); GenConfigForm configFormData = genConfigConverter.toGenConfigForm(genConfig, genFieldConfigs);
return configFormData; return configFormData;
} }
/**
* 保存代码生成配置
*
* @param formData 代码生成配置表单
*/
@Override @Override
public void saveGenConfig(GenConfigForm formData) { public void saveGenConfig(GenConfigForm formData) {
GenConfig genConfig = genConfigConverter.toGenConfigEntity(formData); GenConfig genConfig = genConfigConverter.toGenConfig(formData);
genConfigService.saveOrUpdate(genConfig); genConfigService.saveOrUpdate(genConfig);
List<GenFieldConfig> genFieldConfigs = genConfigConverter.toGenFieldConfigEntity(formData.getFieldConfigs()); List<GenFieldConfig> genFieldConfigs = genConfigConverter.toGenFieldConfig(formData.getFieldConfigs());
if (CollectionUtil.isEmpty(genFieldConfigs)) { if (CollectionUtil.isEmpty(genFieldConfigs)) {
throw new BusinessException("字段配置不能为空"); throw new BusinessException("字段配置不能为空");
@@ -221,13 +221,13 @@ public class GeneratorServiceImpl implements GeneratorService {
private String getFileName(String entityName, String templateName, String extension) { private String getFileName(String entityName, String templateName, String extension) {
if (templateName.equals("Entity")) { if ("Entity".equals(templateName)) {
return entityName + extension; return entityName + extension;
} }
if (templateName.equals("MapperXml")) { if ("MapperXml".equals(templateName)) {
return entityName + "Mapper" + extension; return entityName + "Mapper" + extension;
} }
if (templateName.equals("API") || templateName.equals("VIEW")) { if ("API".equals(templateName) || "VIEW".equals(templateName)) {
return StrUtil.toSymbolCase(entityName, '-') + extension; return StrUtil.toSymbolCase(entityName, '-') + extension;
} }
return entityName + templateName + extension; return entityName + templateName + extension;
@@ -235,13 +235,13 @@ public class GeneratorServiceImpl implements GeneratorService {
private String getFilePath(String templateName, String packageName, String subPackageName) { private String getFilePath(String templateName, String packageName, String subPackageName) {
String path; String path;
if (templateName.equals("MapperXml")) { if ("MapperXml".equals(templateName)) {
path = (applicationName path = (applicationName
+ File.separator + File.separator
+ "src" + File.separator + "main" + File.separator + "resources" + "src" + File.separator + "main" + File.separator + "resources"
+ File.separator + subPackageName + File.separator + subPackageName
).replace(".", File.separator); ).replace(".", File.separator);
} else if (templateName.equals("API") || templateName.equals("VIEW")) { } else if ("API".equals(templateName) || "VIEW".equals(templateName)) {
path = ("vue3-element-admin" path = ("vue3-element-admin"
+ File.separator + File.separator
+ "src" + File.separator + subPackageName + "src" + File.separator + subPackageName
@@ -277,7 +277,7 @@ public class GeneratorServiceImpl implements GeneratorService {
bindMap.put("tableName", genConfig.getTableName()); bindMap.put("tableName", genConfig.getTableName());
bindMap.put("author", genConfig.getAuthor()); bindMap.put("author", genConfig.getAuthor());
bindMap.put("lowerFirstEntityName", StrUtil.lowerFirst(entityName)); bindMap.put("lowerFirstEntityName", StrUtil.lowerFirst(entityName));
bindMap.put("tableComment", StrUtil.replace(genConfig.getComment(), "", Strings.EMPTY)); bindMap.put("tableComment", genConfig.getBusinessName());
bindMap.put("fieldConfigs", fieldConfigs); bindMap.put("fieldConfigs", fieldConfigs);
for (GenFieldConfig fieldConfig : fieldConfigs) { for (GenFieldConfig fieldConfig : fieldConfigs) {