do_sub.vm 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. #set ($subTable = $subTables.get($subIndex))##当前表
  2. #set ($subColumns = $subColumnsList.get($subIndex))##当前字段数组
  3. package ${basePackage}.module.${subTable.moduleName}.dal.dataobject.${subTable.businessName};
  4. import lombok.*;
  5. import java.util.*;
  6. #foreach ($column in $subColumns)
  7. #if (${column.javaType} == "BigDecimal")
  8. import java.math.BigDecimal;
  9. #end
  10. #if (${column.javaType} == "LocalDateTime")
  11. import java.time.LocalDateTime;
  12. #end
  13. #end
  14. import com.baomidou.mybatisplus.annotation.*;
  15. import ${BaseDOClassName};
  16. ## 处理 Schema 注解(仅 DO 模式)
  17. #if ($voType == 20)
  18. import io.swagger.v3.oas.annotations.media.Schema;
  19. #foreach ($column in $columns)
  20. #if ("$!column.dictType" != "")## 有设置数据字典
  21. import ${DictFormatClassName};
  22. import ${DictConvertClassName};
  23. #break
  24. #end
  25. #end
  26. #end
  27. /**
  28. * ${subTable.classComment} DO
  29. *
  30. * @author ${subTable.author}
  31. */
  32. @TableName("${subTable.tableName.toLowerCase()}")
  33. @KeySequence("${subTable.tableName.toLowerCase()}_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
  34. @Data
  35. @EqualsAndHashCode(callSuper = true)
  36. @ToString(callSuper = true)
  37. @Builder
  38. @NoArgsConstructor
  39. @AllArgsConstructor
  40. ## 处理 Schema 注解(仅 DO 模式)
  41. #if ($voType == 20)
  42. @Schema(description = "${sceneEnum.name} - ${table.classComment} Response VO")
  43. #end
  44. public class ${subTable.className}DO extends BaseDO {
  45. #foreach ($column in $subColumns)
  46. #if (!${baseDOFields.contains(${column.javaField})})##排除 BaseDO 的字段
  47. /**
  48. * ${column.columnComment}
  49. #if ("$!column.dictType" != "")##处理枚举值
  50. *
  51. * 枚举 {@link TODO ${column.dictType} 对应的类}
  52. #end
  53. */
  54. #if (${column.primaryKey})##处理主键
  55. @TableId#if (${column.javaType} == 'String')(type = IdType.INPUT)#end
  56. #end
  57. #if ($voType == 20)
  58. ## 1. 处理 Swagger 注解
  59. @Schema(description = "${column.columnComment}"#if (!${column.nullable}), requiredMode = Schema.RequiredMode.REQUIRED#end#if ("$!column.example" != ""), example = "${column.example}"#end)
  60. #end
  61. ## 2. 处理字段定义
  62. private ${column.javaType} ${column.javaField};
  63. #end
  64. #end
  65. }