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-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

Spring Boot结成MyBatis-Plus最全配置指南

《SpringBoot结成MyBatis-Plus最全配置指南》本文主要介绍了SpringBoot结成MyBatis-Plus最全配置指南,包括依赖引入、配置数据源、Mapper扫描、基本CRUD操... 目录前言详细操作一.创建项目并引入相关依赖二.配置数据源信息三.编写相关代码查zsRArly询数据库数

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Linux修改pip临时目录方法的详解

《Linux修改pip临时目录方法的详解》在Linux系统中,pip在安装Python包时会使用临时目录(TMPDIR),但默认的临时目录可能会受到存储空间不足或权限问题的影响,所以本文将详细介绍如何... 目录引言一、为什么要修改 pip 的临时目录?1. 解决存储空间不足的问题2. 解决权限问题3. 提

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程