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

相关文章

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

mybatis-plus如何根据任意字段saveOrUpdateBatch

《mybatis-plus如何根据任意字段saveOrUpdateBatch》MyBatisPlussaveOrUpdateBatch默认按主键判断操作类型,若需按其他唯一字段(如agentId、pe... 目录使用场景方法源码方法改造首先在service层定义接口service层接口实现总结使用场景my

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec