easy code 模板案例 (author作者 修改+swagger-ui+mybatis plus)

2023-10-12 18:01

本文主要是介绍easy code 模板案例 (author作者 修改+swagger-ui+mybatis plus),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

pojo 

##引入宏定义
$!{define.vm}
##使用宏定义设置回调(保存位置与文件后缀)
#save("/pojo", ".java")
##使用宏定义设置包后缀
#setPackageSuffix("pojo")
##使用全局变量实现默认包导入
$!{autoImport.vm}
import java.io.Serializable;
##使用宏定义实现类注释信息
#tableComment("实体类")  $!entityName
@TableName("$tableInfo.name")
@ApiModel(value = "$!{tableInfo.comment}")
public class $!{tableInfo.name} implements Serializable {#foreach($column in $tableInfo.pkColumn )#if(${column.comment})@TableId(value = "$tableInfo.pkColumn", type = IdType.AUTO)#break#end#end#foreach($column in $tableInfo.fullColumn)#if(${column.comment})/*** ${column.comment}*/#end@ApiModelProperty(value = "$!column.name")private $!{tool.getClsNameByFullName($column.type)} $!{column.name};#end#foreach($column in $tableInfo.fullColumn)##使用宏定义实现get,set方法#getSetMethod($column)#end
}

controller

##导入宏定义
$!{define.vm}##设置表后缀(宏定义)
#setTableSuffix("Controller")##保存文件(宏定义)
#save("/controller", "Controller.java")##包路径(宏定义)
#setPackageSuffix("controller")##定义服务名
#set($serviceName = $!tool.append($!tool.firstLowerCase($!tableInfo.name), "Service"))##定义实体对象名
#set($entityName = $!tool.firstLowerCase($!tableInfo.name))import $!{tableInfo.savePackageName}.pojo.$!tableInfo.name;
import $!{tableInfo.savePackageName}.service.$!{tableInfo.name}Service;
import org.springframework.web.bind.annotation.*;import javax.annotation.Resource;
import java.io.Serializable;
import java.util.List;##表注释(宏定义)
#tableComment("表控制层")
@Slf4j
@Api(tags = "$!tableInfo.name 控制层")
@RestController("$!tool.firstLowerCase($!tableInfo.name)")
public class $!{tableName} {/*** 服务对象*/@Resourceprivate $!{tableInfo.name}Service $!{serviceName};/*** $!entityName 分页查询所有数据 $!tableInfo.name $!entityName** @param data 分页对象* @return 所有数据*/@ApiOperation(value = "分页查询所有数据", response = Result.class)@DynamicParameters(name = "data", properties = {@DynamicParameter(name = "pageNo", value = "页码", example = "1", required = true),@DynamicParameter(name = "pageSize", value = "条数", example = "10", required = true),@DynamicParameter(name = "replyType", value = "回复的对象1 2", example = "1", required = true),@DynamicParameter(name = "type", value = "xx", example = "1", required = true),@DynamicParameter(name = "parentId", value = "父 id", example = "1", required = true),})@PostMapping(value = "/selectAll")public Result selectAll(@RequestBody JSONObject data) {try {PageInfo info = $!{serviceName}.selectAll(data);return Result.ok(info);} catch (Exception e) {e.printStackTrace();log.info(e.toString());return Result.fail();}}/*** 通过主键查询单条数据** @param id 主键* @return 单条数据*/@ApiOperation(value = "主键查询单条数据", response = Result.class)@DynamicParameters(name = "data", properties = {@DynamicParameter(name = "id", value = "id", example = "1", required = true),})@GetMapping("{id}")public Result selectOne(@PathVariable Serializable id) {try {return  Result.ok($!{serviceName}.getById(id));} catch (Exception e) {e.printStackTrace();log.info(e.toString());return Result.fail();}}/*** 新增数据** @param $!entityName 实体对象* @return 新增结果*/@ApiOperation(value = "新增数据", response = Result.class)@DynamicParameters(name = "data", properties = {//@DynamicParameter(name = "pageNo", value = "页码", example = "1", required = true),//@DynamicParameter(name = "pageSize", value = "条数", example = "10", required = true),//@DynamicParameter(name = "replyType", value = "回复的对象1 2", example = "1", required = true),//@DynamicParameter(name = "type", value = "1表白墙 2交友 3工作 4黑企", example = "1", required = true),//@DynamicParameter(name = "parentId", value = "父 id", example = "1", required = true),})@PostMappingpublic Result insert(@RequestBody $!tableInfo.name $!entityName) {try {return  Result.ok($!{serviceName}.save($!entityName));} catch (Exception e) {e.printStackTrace();log.info(e.toString());return Result.fail();}}/*** 修改数据** @param $!entityName 实体对象* @return 修改结果*/@ApiOperation(value = "修改数据", response = Result.class)@DynamicParameters(name = "data", properties = {//@DynamicParameter(name = "pageNo", value = "页码", example = "1", required = true),//@DynamicParameter(name = "pageSize", value = "条数", example = "10", required = true),//@DynamicParameter(name = "replyType", value = "回复的1 2", example = "1", required = true),//@DynamicParameter(name = "type", value = "", example = "1", required = true),//@DynamicParameter(name = "parentId", value = "父 id", example = "1", required = true),})@PutMappingpublic Result update(@RequestBody $!tableInfo.name $!entityName) {try {return  Result.ok($!{serviceName}.updateById($!entityName));} catch (Exception e) {e.printStackTrace();log.info(e.toString());return Result.fail();}}/*** 删除数据** @param idList 主键结合* @return 删除结果*/@ApiOperation(value = "删除数据", response = Result.class)@DynamicParameters(name = "data", properties = {@DynamicParameter(name = "idList", value = "id", example = "1,2", required = true),})@DeleteMappingpublic Result delete(@RequestParam("idList") List<Long> idList) {try {return Result.ok($!{serviceName}.removeByIds(idList));} catch (Exception e) {e.printStackTrace();log.info(e.toString());return Result.fail();}}
}

mapper

##导入宏定义
$!{define.vm}##设置表后缀(宏定义)
#setTableSuffix("Mapper")##保存文件(宏定义)
#save("/mapper", "Mapper.java")##包路径(宏定义)
#setPackageSuffix("mapper")import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import $!{tableInfo.savePackageName}.pojo.$!tableInfo.name;##表注释(宏定义)
#tableComment("表数据库访问层")
@Mapper
public interface $!{tableName} extends BaseMapper<$!tableInfo.name> {}

service

##导入宏定义
$!{define.vm}##设置表后缀(宏定义)
#setTableSuffix("Service")##保存文件(宏定义)
#save("/service", "Service.java")##包路径(宏定义)
#setPackageSuffix("service")import com.baomidou.mybatisplus.extension.service.IService;
import $!{tableInfo.savePackageName}.pojo.$!tableInfo.name;##表注释(宏定义)
#tableComment("表服务接口")
public interface $!{tableName} extends IService<$!tableInfo.name> {
public PageInfo selectAll(JSONObject data);
}

serviceImpl

##导入宏定义
$!{define.vm}##设置表后缀(宏定义)
#setTableSuffix("ServiceImpl")##保存文件(宏定义)
#save("/service/impl", "ServiceImpl.java")##包路径(宏定义)
#setPackageSuffix("service.impl")
##定义服务名
#set($mapperName = $!tool.append($!tool.firstLowerCase($!tableInfo.name), "Mapper"))import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import $!{tableInfo.savePackageName}.mapper.$!{tableInfo.name}Mapper;
import $!{tableInfo.savePackageName}.pojo.$!{tableInfo.name};
import $!{tableInfo.savePackageName}.service.$!{tableInfo.name}Service;
import org.springframework.stereotype.Service;##表注释(宏定义)
#tableComment("表服务实现类")
@Service("$!tool.firstLowerCase($tableInfo.name)Service")
public class $!{tableName} extends ServiceImpl<$!{tableInfo.name}Mapper, $!{tableInfo.name}> implements $!{tableInfo.name}Service {@Autowired$!{tableInfo.name}Mapper $!{mapperName};/*** 分页查询所有数据* @param data* @return*/@Overridepublic PageInfo selectAll(JSONObject data) {QueryWrapper<$!{tableInfo.name}> wrapper = new QueryWrapper<>();wrapper.eq("type", data.getString("type"));wrapper.eq("parent_id", data.getInteger("parentId"));//wrapper.eq("createTime", data.get("createTime") + " 00:00:00");wrapper.orderByDesc("create_time");PageHelper.startPage(data.getInteger("pageNo"), data.getInteger("pageSize"));List<$!{tableInfo.name}> list = $!{mapperName}.selectList(wrapper);PageInfo info = new PageInfo(list);return info;}
}

修改作者

路径:Settings --> Other Settings---> EasyCode

这篇关于easy code 模板案例 (author作者 修改+swagger-ui+mybatis plus)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/197524

相关文章

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.