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

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

MyBatis ResultMap 的基本用法示例详解

《MyBatisResultMap的基本用法示例详解》在MyBatis中,resultMap用于定义数据库查询结果到Java对象属性的映射关系,本文给大家介绍MyBatisResultMap的基本... 目录MyBATis 中的 resultMap1. resultMap 的基本语法2. 简单的 resul

Mybatis的分页实现方式

《Mybatis的分页实现方式》MyBatis的分页实现方式主要有以下几种,每种方式适用于不同的场景,且在性能、灵活性和代码侵入性上有所差异,对Mybatis的分页实现方式感兴趣的朋友一起看看吧... 目录​1. 原生 SQL 分页(物理分页)​​2. RowBounds 分页(逻辑分页)​​3. Page

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Mybatis Plus Join使用方法示例详解

《MybatisPlusJoin使用方法示例详解》:本文主要介绍MybatisPlusJoin使用方法示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录1、pom文件2、yaml配置文件3、分页插件4、示例代码:5、测试代码6、和PageHelper结合6

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

Swagger在java中的运用及常见问题解决

《Swagger在java中的运用及常见问题解决》Swagger插件是一款深受Java开发者喜爱的工具,它在前后端分离的开发模式下发挥着重要作用,:本文主要介绍Swagger在java中的运用及常... 目录前言1. Swagger 的主要功能1.1 交互式 API 文档1.2 客户端 SDK 生成1.3