目录

工欲善其事

实践出真知

活跃标签: linux java mysql 待分类 js springboot win10 电路 vue macOS nginx windows esp32 git docker idea maven esp8266 python Arduino

存档:

[ idea ] 代码生成器 EasyCode

{
  "author" : "makejava",
  "version" : "1.2.8",
  "userSecure" : "",
  "currTypeMapperGroupName" : "Default",
  "currTemplateGroupName" : "limsV2.1",
  "currColumnConfigGroupName" : "Default",
  "currGlobalConfigGroupName" : "Default",
  "typeMapper" : {
    "Default" : {
      "name" : "Default",
      "elementList" : [ {
        "matchType" : "REGEX",
        "columnType" : "varchar(\\(\\d+\\))?",
        "javaType" : "java.lang.String"
      }, {
        "matchType" : "REGEX",
        "columnType" : "char(\\(\\d+\\))?",
        "javaType" : "java.lang.String"
      }, {
        "matchType" : "REGEX",
        "columnType" : "(tiny|medium|long)*text",
        "javaType" : "java.lang.String"
      }, {
        "matchType" : "REGEX",
        "columnType" : "decimal(\\(\\d+,\\d+\\))?",
        "javaType" : "java.lang.Double"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "integer",
        "javaType" : "java.lang.Integer"
      }, {
        "matchType" : "REGEX",
        "columnType" : "(tiny|small|medium)*int(\\(\\d+\\))?",
        "javaType" : "java.lang.Integer"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "int4",
        "javaType" : "java.lang.Integer"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "int8",
        "javaType" : "java.lang.Long"
      }, {
        "matchType" : "REGEX",
        "columnType" : "bigint(\\(\\d+\\))?",
        "javaType" : "java.lang.Long"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "date",
        "javaType" : "java.time.LocalDate"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "datetime",
        "javaType" : "java.time.LocalDateTime"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "timestamp",
        "javaType" : "java.time.LocalDateTime"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "time",
        "javaType" : "java.time.LocalTime"
      }, {
        "matchType" : "ORDINARY",
        "columnType" : "boolean",
        "javaType" : "java.lang.Boolean"
      } ]
    }
  },
  "template" : {
    "limsV2.1" : {
      "name" : "limsV2.1",
      "elementList" : [ {
        "name" : "controller.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##设置表后缀(宏定义)\n#setTableSuffix(\"StatisticsController\")\n#getTableNoPreSuffix(\"Statistics\")\n\n##保存文件(宏定义)\n#save(\"/controller\", \"StatisticsController.java\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"controller\")\n\n##定义服务名\n#set($serviceName = $!tool.append($!tool.firstLowerCase($!tableInfo.name), \"Service\"))\n\n##定义实体对象名\n##set($entityName = $!tool.firstLowerCase($!tableInfo.name))\nimport com.isimple.common.http.ResponseResult;\nimport com.isimple.common.log.BusinessType;\nimport com.isimple.common.log.Log;\nimport com.isimple.core.boot.domain.PageData;\n\nimport $!{tableInfo.savePackageName}.dto.$!{entityName}Dto;\nimport $!{tableInfo.savePackageName}.dto.query.$!{entityName}Query;\nimport $!{tableInfo.savePackageName}.service.$!{entityName}Service;\n\n\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.bind.annotation.RequestBody;\nimport org.springframework.web.bind.annotation.RequestMapping;\nimport org.springframework.web.bind.annotation.RestController;\n\nimport javax.annotation.Resource;\nimport java.io.Serializable;\nimport java.util.List;\n\n##表注释(宏定义)\n#tableComment(\"表控制层\")\n@RestController\n@RequestMapping(\"$!{entityName}\")\npublic class $!{tableName} {\n    /**\n     * 服务对象\n     */\n    @Autowired\n    private $!{entityName}Service service;\n\n  /**\n     * @Author ${author}\n     * @Description: ${functionName}分页查询\n     * @Date ${datetime}\n     * @Param query 查询对象\n     * @return ResponseResult\n     */\n    @Log(title = \"${functionName}\", businessType = BusinessType.SELECT)\n    //@PreAuthorize(\"@ss.hasPermi('${permissionPrefix}:page')\")\n    @PostMapping(\"page\")\n    public ResponseResult<PageData<$!{entityName}Dto>> page(@RequestBody $!{entityName}Query query) {\n        return ResponseResult.success(service.page(query));\n    }\n\n}\n"
      }, {
        "name" : "service.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##设置表后缀(宏定义)\n#setTableSuffix(\"StatisticsService\")\n#getTableNoPreSuffix(\"Statistics\")\n\n##保存文件(宏定义)\n#save(\"/service\", \"StatisticsService.java\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"service\")\n \nimport com.isimple.core.boot.service.base.IBaseService;\nimport com.isimple.core.boot.domain.PageData;\n\nimport $!{tableInfo.savePackageName}.model.$!{entityName};\nimport $!{tableInfo.savePackageName}.dto.$!{entityName}Dto;\nimport $!{tableInfo.savePackageName}.dto.query.$!{entityName}Query;\n\n##表注释(宏定义)\n#tableComment(\"表服务接口\")\npublic interface $!{tableName} extends IBaseService<$!entityName,String> {\n\n    /**\n     * 分页查询\n     * @param query 查询的对象\n     * @return 分页结果集\n     */\n    PageData<$!{entityName}Dto> page($!{entityName}Query query);\n        \n}\n"
      }, {
        "name" : "serviceImpl.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##设置表后缀(宏定义)\n#setTableSuffix(\"StatisticsServiceImpl\")\n#getTableNoPreSuffix(\"Statistics\")\n\n\n##保存文件(宏定义)\n#save(\"/service/impl\", \"StatisticsServiceImpl.java\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"service.impl\")\n\nimport com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;\nimport com.baomidou.mybatisplus.extension.plugins.pagination.Page;\nimport com.isimple.core.boot.domain.PageData;\nimport com.isimple.core.boot.domain.PageParam;\nimport com.isimple.core.boot.service.base.BaseService;\nimport com.isimple.core.boot.utils.ModelUtil;\nimport com.isimple.sdnpc.lims.core.utils.QueryWrapperUtils;\nimport org.springframework.stereotype.Service;\n\nimport $!{tableInfo.savePackageName}.dto.$!{entityName}Dto;\nimport $!{tableInfo.savePackageName}.dto.query.$!{entityName}Query;\nimport $!{tableInfo.savePackageName}.model.$!{entityName};\nimport $!{tableInfo.savePackageName}.model.converter.$!{entityName}ModelConverter;\nimport $!{tableInfo.savePackageName}.mapper.$!{entityName}Mapper;\nimport $!{tableInfo.savePackageName}.service.$!{entityName}Service;\n\n\n##表注释(宏定义)\n#tableComment(\"表服务实现类\")\n@Service\npublic class $!{tableName} extends BaseService<$!{entityName}Mapper, $!{entityName},String> implements $!{entityName}Service {\n\n    /**\n     * 分页查询\n     * @param query 查询的对象\n     * @return 分页结果集\n     */\n    @Override\n    public PageData<$!{entityName}Dto> page($!{entityName}Query query){\n        $!{entityName}Dto filter = query.getFilter();\n        QueryWrapper qw = QueryWrapperUtils.init(filter);\n        final PageParam pageParam = query.getPage();\n        return ModelUtil.makeResponseData(page(new Page<>(pageParam.getPageNum(), pageParam.getPageSize()), qw), $!{entityName}ModelConverter.INSTANCE);\n    }\n\n}\n"
      }, {
        "name" : "mapper.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##设置表后缀(宏定义)\n#setTableSuffix(\"StatisticsMapper\")\n#getTableNoPreSuffix(\"Statistics\")\n\n##保存文件(宏定义)\n#save(\"/mapper\", \"StatisticsMapper.java\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"mapper\")\n \nimport com.isimple.core.boot.dao.BaseDaoMapper;\nimport $!{tableInfo.savePackageName}.model.$!entityName;\n\n##表注释(宏定义)\n#tableComment(\"表数据库访问层\")\npublic interface $!{tableName} extends BaseDaoMapper<$!entityName> {\n\n}\n"
      }, {
        "name" : "entity.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##保存文件(宏定义)\n#save(\"/model\", \"Statistics.java\")\n#getTableNoPreSuffix(\"Statistics\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"model\")\n\n##自动导入包(全局变量)\n$!{autoImport.vm}\nimport com.baomidou.mybatisplus.annotation.TableName;\nimport com.isimple.core.boot.domain.BaseModel;\nimport lombok.Data;\nimport lombok.EqualsAndHashCode;\nimport lombok.ToString;\n\nimport java.util.Date;\nimport java.time.LocalDate;\nimport java.util.HashMap;\nimport java.util.List;\nimport java.time.LocalDateTime;\n\n##表注释(宏定义)\n#tableComment(\"表实体类\")\n@Data\n@EqualsAndHashCode(callSuper = true)\n@TableName(value = \"$!{tableInfo.obj.name}\")\n@ToString(callSuper = true)\npublic class $!{entityName} extends BaseModel {\n\n#foreach($column in $tableInfo.fullColumn)\n\n    #if(${column.comment})\n    /*\n     * ${column.comment} \n     */ #end\n    \n    private $!{tool.getClsNameByFullName($column.type)} $!{column.name};    \n#end\n\n}\n"
      }, {
        "name" : "Query.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n#setTableSuffix(\"StatisticsQuery\")\n#getTableNoPreSuffix(\"Statistics\")\n##保存文件(宏定义)\n#save(\"/dto/query\", \"StatisticsQuery.java\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"dto.query\")\n\n##自动导入包(全局变量)\n\nimport com.isimple.core.boot.domain.OrderParam;\nimport com.isimple.core.boot.domain.PageParam;\nimport $!{tableInfo.savePackageName}.dto.$!{entityName}Dto;\nimport lombok.Data;\nimport java.io.Serializable;\n\n##表注释(宏定义)\n#tableComment(\"表实体类\")\n@Data\npublic class $!{tableName} implements Serializable {\n\n    private PageParam page;\n\n    private OrderParam order;\n\n    private $!{entityName}Dto filter;\n\n}\n"
      }, {
        "name" : "dao.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##设置表后缀(宏定义)\n#setTableSuffix(\"StatisticsDto\")\n#getTableNoPreSuffix(\"Statistics\")\n\n##保存文件(宏定义)\n#save(\"/dto\", \"StatisticsDto.java\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"dto\")\n \nimport com.alibaba.excel.annotation.ExcelIgnoreUnannotated;\nimport com.alibaba.excel.annotation.ExcelProperty;\nimport com.alibaba.excel.annotation.format.DateTimeFormat;\nimport com.fasterxml.jackson.annotation.JsonFormat;\nimport com.isimple.common.poi.excel.annotation.Excel;\nimport com.isimple.sdnpc.lims.core.dto.common.EnclosureProperty;\nimport com.isimple.sdnpc.lims.core.dto.BusiEnclosureDto;\nimport com.isimple.sdnpc.lims.core.dto.common.FlowProperty;\nimport com.isimple.sdnpc.lims.core.dto.common.DocAndFileProperty;\nimport java.util.Date;\nimport java.time.LocalDate;\nimport java.util.HashMap;\nimport java.util.List;\nimport java.time.LocalDateTime;\n\nimport lombok.Data;\n\nimport javax.validation.constraints.NotNull;\nimport java.io.Serializable;\nimport java.time.LocalDateTime;\n\n##表注释(宏定义)\n#tableComment(\"表数据库访问层\")\n@Data\n@Excel(\"$!{tableName}\")\n@ExcelIgnoreUnannotated\npublic class $!{tableName} implements Serializable  {\n\n\n#foreach($column in $tableInfo.fullColumn)\n    #if(${column.comment})\n    // ${column.comment}\n    @ExcelProperty(value = \"${column.comment}\")\n    #end\n    private $!{tool.getClsNameByFullName($column.type)} $!{column.name};\n    \n#end\n}\n"
      }, {
        "name" : "converter.java.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##设置表后缀(宏定义)\n#setTableSuffix(\"StatisticsMapper\")\n#getTableNoPreSuffix(\"Statistics\")\n\n##保存文件(宏定义)\n#save(\"/model/converter\", \"StatisticsModelConverter.java\")\n\n##包路径(宏定义)\n#setPackageSuffix(\"model.converter\")\n \n \nimport com.isimple.core.boot.mapper.BaseModelMapper;\nimport org.mapstruct.Mapper;\nimport org.mapstruct.factory.Mappers;\n\nimport $!{tableInfo.savePackageName}.dto.$!{entityName}Dto;\nimport $!{tableInfo.savePackageName}.model.$!{entityName};\n\n/**\n * @ClassName: $!{entityName}ModelConverter}\n * @Author: ${author}\n * @Date: ${datetime}\n * @Copyright 国核信息科技有限公司版权所有\n * @Version: V1.0\n * @Description:\n */\n@Mapper\npublic interface $!{entityName}ModelConverter extends BaseModelMapper<$!{entityName}Dto, $!{entityName}> {\n\n    $!{entityName}ModelConverter INSTANCE = Mappers.getMapper($!{entityName}ModelConverter.class);\n\n}"
      }, {
        "name" : "mapper.xml.vm",
        "code" : "##引入mybatis支持\n$!{mybatisSupport.vm}\n$!{definels.vm}\n\n##设置保存名称与保存位置\n$!callback.setFileName($tool.append($!{tableInfo.name}, \"StatisticsMapper.xml\"))\n$!callback.setSavePath($tool.append($modulePath, \"/src/main/resources/mapper\"))\n\n#getTableNoPreSuffix(\"Statistics\")\n\n##保存文件(宏定义)\n#save(\"/mapper\", \"StatisticsMapper.xml\")\n\n##拿到主键\n#if(!$tableInfo.pkColumn.isEmpty())\n    #set($pk = $tableInfo.pkColumn.get(0))\n#end\n\n<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE mapper PUBLIC \"-//mybatis.org//DTD Mapper 3.0//EN\" \"http://mybatis.org/dtd/mybatis-3-mapper.dtd\">\n<mapper namespace=\"$!{tableInfo.savePackageName}.mapper.$!{entityName}Mapper\">\n\n    <resultMap type=\"$!{tableInfo.savePackageName}.model.$!{entityName}\" id=\"$!{entityName}Map\">\n#foreach($column in $tableInfo.fullColumn)\n        <result property=\"$!column.name\" column=\"$!column.obj.name\" jdbcType=\"$!column.ext.jdbcType\"/>\n#end\n    </resultMap>\n \n\n</mapper>\n"
      }, {
        "name" : "index.vue.vm",
        "code" : "##导入宏定义\n$!{definels.vm}\n\n##保存文件(宏定义)\n#save(\"\", \"List.vue\")\n#getTableNoPreSuffix(\"Statistics\")\n\n<template>\n  <div class=\"app-container\">\n\n    <el-table v-loading=\"loading\" :data=\"dataList\" @selection-change=\"handleSelectionChange\">\n      <el-table-column show-overflow-tooltip type=\"selection\" width=\"55\" align=\"center\"/>\n\n     #foreach($column in $tableInfo.fullColumn)\n      <el-table-column label=\"${column.comment}\" align=\"center\" prop=\"$!{column.name}\"/>\n      #end\n    </el-table>\n\n  </div>\n</template>\n\n<script>\nimport {pageBusiSampleTestOriginalRecordTr12} from '@/api/sdnpc/testing/testOrig/busiSampleTestOriginalRecordTr12';\n\nexport default {\n  name: 'StatisticsTr12',\n  data() {\n    return {\n      // 遮罩层\n      loading: true,\n      // 选择框选择的对象数组\n      selectedList: [],\n      // 选中数组\n      ids: [],\n      // 非单个禁用\n      single: true,\n      // 非多个禁用\n      multiple: true,\n      // 显示搜索条件\n      showSearch: true,\n      // 总条数\n      total: 0,\n      // TR12-空气吸收累积剂量测量记录表格数据\n      dataList: [],\n      // 弹出层标题\n      title: '',\n      // 是否显示弹出层\n      open: false,\n      dateRange: {},\n      // 查询参数\n      queryParams: {\n        page: {\n          pageNum: 1,\n          pageSize: 10\n        },\n        filter: {}\n      }\n    }\n  },\n  methods: {\n    handleLoad(queryParams) {\n      this.loading = true;\n      pageBusiSampleTestOriginalRecordTr12(queryParams).then(response => {\n        this.dataList = response.data && response.data.dataList\n        this.total = response.data && response.data.totalCount || 0\n        this.loading = false\n      })\n    },\n    // 搜索按钮操作\n    handleQuery() {\n      this.queryParams.page.pageNum = 1\n      this.getPage()\n    },\n    // 重置按钮操作\n    resetQuery() {\n      Object.keys(this.dateRange).forEach(key => this.dateRange[key] = [])\n      this.resetForm('queryForm')\n      this.queryParams.filter = {}\n      this.queryParams.page.pageNum = 1\n      this.handleQuery()\n    },\n    // 多选框选中数据\n    handleSelectionChange(selection) {\n      this.ids = selection.map(item => item.id)\n      this.single = selection.length !== 1\n      this.multiple = !selection.length\n      this.selectedList = selection\n    },\n  }\n};\n</script>\n"
      } ]
    }
  },
  "columnConfig" : {
    "Default" : {
      "name" : "Default",
      "elementList" : [ {
        "title" : "disable",
        "type" : "BOOLEAN",
        "selectValue" : ""
      }, {
        "title" : "support",
        "type" : "SELECT",
        "selectValue" : "add,edit,query,del,ui"
      } ]
    }
  },
  "globalConfig" : {
    "Default" : {
      "name" : "Default",
      "elementList" : [ {
        "name" : "autoImport.vm",
        "value" : "##自动导入包(仅导入实体属性需要的包,通常用于实体类)\n#foreach($import in $importList)\nimport $!import;\n#end"
      }, {
        "name" : "define.vm",
        "value" : "##(Velocity宏定义)\n\n##定义设置表名后缀的宏定义,调用方式:#setTableSuffix(\"Test\")\n#macro(setTableSuffix $suffix)\n    #set($tableName = $!tool.append($tableInfo.name, $suffix))\n#end\n\n##定义设置包名后缀的宏定义,调用方式:#setPackageSuffix(\"Test\")\n#macro(setPackageSuffix $suffix)\n#if($suffix!=\"\")package #end#if($tableInfo.savePackageName!=\"\")$!{tableInfo.savePackageName}.#{end}$!suffix;\n#end\n\n##定义直接保存路径与文件名简化的宏定义,调用方式:#save(\"/entity\", \".java\")\n#macro(save $path $fileName)\n    $!callback.setSavePath($tool.append($tableInfo.savePath, $path))\n    $!callback.setFileName($tool.append($tableInfo.name, $fileName))\n#end\n\n##定义表注释的宏定义,调用方式:#tableComment(\"注释信息\")\n#macro(tableComment $desc)\n/**\n * $!{tableInfo.comment}($!{tableInfo.name})$desc\n *\n * @author $!author\n * @since $!time.currTime()\n */\n#end\n\n##定义GET,SET方法的宏定义,调用方式:#getSetMethod($column)\n#macro(getSetMethod $column)\n\n    public $!{tool.getClsNameByFullName($column.type)} get$!{tool.firstUpperCase($column.name)}() {\n        return $!{column.name};\n    }\n\n    public void set$!{tool.firstUpperCase($column.name)}($!{tool.getClsNameByFullName($column.type)} $!{column.name}) {\n        this.$!{column.name} = $!{column.name};\n    }\n#end"
      }, {
        "name" : "init.vm",
        "value" : "##初始化区域\n\n##去掉表的t_前缀\n$!tableInfo.setName($tool.getClassName($tableInfo.obj.name.replaceFirst(\"book_\",\"\")))\n\n##参考阿里巴巴开发手册,POJO 类中布尔类型的变量,都不要加 is 前缀,否则部分框架解析会引起序列化错误\n#foreach($column in $tableInfo.fullColumn)\n#if($column.name.startsWith(\"is\") && $column.type.equals(\"java.lang.Boolean\"))\n    $!column.setName($tool.firstLowerCase($column.name.substring(2)))\n#end\n#end\n\n##实现动态排除列\n#set($temp = $tool.newHashSet(\"testCreateTime\", \"otherColumn\"))\n#foreach($item in $temp)\n    #set($newList = $tool.newArrayList())\n    #foreach($column in $tableInfo.fullColumn)\n        #if($column.name!=$item)\n            ##带有反回值的方法调用时使用$tool.call来消除返回值\n            $tool.call($newList.add($column))\n        #end\n    #end\n    ##重新保存\n    $tableInfo.setFullColumn($newList)\n#end\n\n##对importList进行篡改\n#set($temp = $tool.newHashSet())\n#foreach($column in $tableInfo.fullColumn)\n    #if(!$column.type.startsWith(\"java.lang.\"))\n        ##带有反回值的方法调用时使用$tool.call来消除返回值\n        $tool.call($temp.add($column.type))\n    #end\n#end\n##覆盖\n#set($importList = $temp)"
      }, {
        "name" : "mybatisSupport.vm",
        "value" : "##针对Mybatis 进行支持,主要用于生成xml文件\n#foreach($column in $tableInfo.fullColumn)\n    ##储存列类型\n    $tool.call($column.ext.put(\"sqlType\", $tool.getField($column.obj.dataType, \"typeName\")))\n    #if($tool.newHashSet(\"java.lang.String\").contains($column.type))\n        #set($jdbcType=\"VARCHAR\")\n    #elseif($tool.newHashSet(\"java.lang.Boolean\", \"boolean\").contains($column.type))\n        #set($jdbcType=\"BOOLEAN\")\n    #elseif($tool.newHashSet(\"java.lang.Byte\", \"byte\").contains($column.type))\n        #set($jdbcType=\"BYTE\")\n    #elseif($tool.newHashSet(\"java.lang.Integer\", \"int\", \"java.lang.Short\", \"short\").contains($column.type))\n        #set($jdbcType=\"INTEGER\")\n    #elseif($tool.newHashSet(\"java.lang.Long\", \"long\").contains($column.type))\n        #set($jdbcType=\"INTEGER\")\n    #elseif($tool.newHashSet(\"java.lang.Float\", \"float\", \"java.lang.Double\", \"double\").contains($column.type))\n        #set($jdbcType=\"NUMERIC\")\n    #elseif($tool.newHashSet(\"java.util.Date\", \"java.sql.Timestamp\", \"java.time.Instant\", \"java.time.LocalDateTime\", \"java.time.OffsetDateTime\", \"\tjava.time.ZonedDateTime\").contains($column.type))\n        #set($jdbcType=\"TIMESTAMP\")\n    #elseif($tool.newHashSet(\"java.sql.Date\", \"java.time.LocalDate\").contains($column.type))\n        #set($jdbcType=\"TIMESTAMP\")\n    #else\n        ##其他类型\n        #set($jdbcType=\"VARCHAR\")\n    #end\n    $tool.call($column.ext.put(\"jdbcType\", $jdbcType))\n#end\n\n##定义宏,查询所有列\n#macro(allSqlColumn)#foreach($column in $tableInfo.fullColumn)$column.obj.name#if($velocityHasNext), #end#end#end\n"
      }, {
        "name" : "definels.vm",
        "value" : "##(Velocity宏定义)\n\n##定义设置表名后缀的宏定义,调用方式:#setTableSuffix(\"Test\")\n#macro(setTableSuffix $suffix)\n    #set($tableName = $tool.getClassName($tableInfo.obj.name.replaceFirst($!tableInfo.preName,\"\")))\n    #set($tableName = $!tool.append($tableName, $suffix))\n#end\n\n##定义设置包名后缀的宏定义,调用方式:#setPackageSuffix(\"Test\")\n#macro(setPackageSuffix $suffix)\n#if($suffix!=\"\")package #end#if($tableInfo.savePackageName!=\"\")$!{tableInfo.savePackageName}.#{end}$!suffix;\n#end\n\n##定义直接保存路径与文件名简化的宏定义,调用方式:#save(\"/entity\", \".java\")\n#macro(save $path $fileName)\n    $!callback.setSavePath($tool.append($tableInfo.savePath, $path))\n    $!callback.setFileName($tool.append($tableInfo.name, $fileName))\n#end\n\n##定义表注释的宏定义,调用方式:#tableComment(\"注释信息\")\n#macro(tableComment $desc)\n/**\n * $!{tableInfo.comment}($!{tableInfo.name})$desc\n *\n * @author $!author\n * @since $!time.currTime()\n */\n#end\n\n##定义GET,SET方法的宏定义,调用方式:#getSetMethod($column)\n#macro(getSetMethod $column)\n\n    public $!{tool.getClsNameByFullName($column.type)} get$!{tool.firstUpperCase($column.name)}() {\n        return $!{column.name};\n    }\n\n    public void set$!{tool.firstUpperCase($column.name)}($!{tool.getClsNameByFullName($column.type)} $!{column.name}) {\n        this.$!{column.name} = $!{column.name};\n    }\n#end\n\n##定义 获取实体类的名字\n#macro(getTableNoPreSuffix $suffix)\n    #set($entityName = $tool.getClassName($tableInfo.obj.name.replaceFirst($!tableInfo.preName,\"\")))\n    #set($entityName = $!tool.append($entityName, $suffix))\n#end\n\n\n\n"
      } ]
    }
  }
}

标题:[ idea ] 代码生成器 EasyCode
作者:llilei
地址:http://solo.llilei.work/articles/2023/11/10/1699612481965.html