EasyCode全自動單表增刪改查!
阿新 • • 發佈:2022-12-02
需要IDEA下載EasyCode外掛
準備好三個基礎Base類
分頁封裝基礎
package com.gton.io; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import java.io.Serializable; /** * @description: 分頁引數物件 * 貧血型模型 * @author: GuoTong * @createTime: 2022-09-24 13:31 * @since JDK 1.8 OR 11 **/ @Data @AllArgsConstructor @NoArgsConstructor public class BasePage implements Serializable { /** * Description: 當前頁 || 預設是從第一頁開始 * * @author: GuoTong * @date: 2022-09-24 13:32:36 */ private long pageIndex = 1; /** * Description: 每頁顯示條數 || 預設是每頁展示10條 * * @author: GuoTong * @date: 2022-09-24 13:32:36 */ private long pageSize = 10; public long getPageIndex() { if (this.pageIndex <= 1) { this.pageIndex = 1; } return pageIndex; } public long getPageSize() { if (this.pageSize <= 1) { this.pageSize = 10; } return pageSize; } }
分頁請求物件
package com.gton.io; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import java.time.LocalDateTime; /** * @description: 通用請求 * @author: GuoTong * @createTime: 2022-12-02 14:09 * @since JDK 1.8 OR 11 **/ @Data @NoArgsConstructor @AllArgsConstructor public class BaseLimitRequest<T> extends BasePage { /** * Description: 實體類 */ private T requestBody; /** * Description: 開始時間 */ private LocalDateTime beginTime; /** * Description: 結束時間 */ private LocalDateTime endTime; }
基本通用響應物件
package com.gton.io; import com.gton.util.ContextCommonMsg; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.NoArgsConstructor; import lombok.experimental.Accessors; import java.io.Serializable; /** * @description: 通用返回物件 * 貧血型模型 * @author: GuoTong * @createTime: 2022-09-24 13:16 * @since JDK 1.8 OR 11 **/ @Data @Builder @NoArgsConstructor @AllArgsConstructor @Accessors(chain = true) public class Resp<T> implements Serializable { //狀態碼 private String code; //提示資訊 private String msg; //返回的資料 private T data; /** * Description:常用返回資料抽離 */ public static <T> Resp<T> LoginOk() { return new Resp<T>(). setCode(ContextCommonMsg.LOGIN_SUCCESS_CODE). setMsg(ContextCommonMsg.LOGIN_SUCCESS_MSG); } public static <T> Resp<T> LoginFail() { return new Resp<T>(). setCode(ContextCommonMsg.LOGIN_FAIL_CODE). setMsg(ContextCommonMsg.LOGIN_FAIL_MSG); } public static <T> Resp<T> error(String errorMsg) { return new Resp<T>(). setCode(ContextCommonMsg.FAIL_CODE). setMsg(errorMsg); } public static <T> Resp<T> error() { return new Resp<T>(). setCode(ContextCommonMsg.FAIL_CODE). setMsg(ContextCommonMsg.FAIL_MSG); } public static <T> Resp<T> error(String errorMsg, String failCode) { return new Resp<T>(). setCode(failCode). setMsg(errorMsg); } public static <T> Resp<T> error(String errorMsg, String failCode, T data) { return new Resp<T>(). setCode(failCode). setData(data). setMsg(errorMsg); } public static <T> Resp<T> Ok(T data) { return new Resp<T>(). setCode(ContextCommonMsg.SUCCESS_CODE). setMsg(ContextCommonMsg.SUCCESS_MSG). setData(data); } public static <T> Resp<T> Ok() { return new Resp<T>(). setCode(ContextCommonMsg.SUCCESS_CODE). setMsg(ContextCommonMsg.SUCCESS_MSG); } public static <T> Resp<T> Ok(T data, String msg) { return new Resp<T>(). setCode(ContextCommonMsg.SUCCESS_CODE). setMsg(msg). setData(data); } public static <T> Resp<T> Ok(T data, String msg, String successCode) { return new Resp<T>(). setCode(successCode). setMsg(msg). setData(data); } }
分頁查詢通用響應
package com.gton.io;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;
/**
* @description: 通用響應
* @author: GuoTong
* @createTime: 2022-12-02 14:12
* @since JDK 1.8 OR 11
**/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class BaseLimitResponse<T> extends BasePage {
/**
* Description: 當前頁資料
*/
private List<T> responseBody;
/**
* Description: 總條數
*/
private long totalNum;
/**
* Description: 總頁數
*/
private long pageCount;
public static <T> BaseLimitResponse<T> getInstance() {
return new BaseLimitResponse<>();
}
/**
* Description: 獲取響應物件
*
* @param responseBody 當前頁資料
* @param totalNum 總資料
* @param pageCount 總頁數
* @param pageIndex 當前頁
* @param pageSize 每頁展示資料大小
* @author: GuoTong
* @date: 2022-12-02 15:01:48
* @return:com.gton.io.BaseLimitResponse<T>
*/
public static <T> BaseLimitResponse<T> getInstance(List<T> responseBody, long totalNum, long pageCount, long pageIndex, long pageSize) {
BaseLimitResponse<T> response = new BaseLimitResponse<>();
response.setResponseBody(responseBody);
response.setPageCount(pageCount);
response.setTotalNum(totalNum);
response.setPageSize(pageSize);
response.setPageIndex(pageIndex);
return response;
}
}
模板
controller.java.vmCopy
##匯入巨集定義
$!{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 com.baomidou.mybatisplus.core.metadata.IPage;
import com.gton.io.BaseLimitRequest;
import com.gton.io.BaseLimitResponse;
import com.gton.io.Resp;
import $!{tableInfo.savePackageName}.entity.$!tableInfo.name;
import $!{tableInfo.savePackageName}.service.$!{tableInfo.name}Service;
import org.springframework.web.bind.annotation.*;
import com.gton.annotation.SwaggerScanClass;
import java.io.Serializable;
import java.util.List;
##表註釋(巨集定義)
#tableComment("表控制層")
@RestController
@RequestMapping("$!tool.firstLowerCase($!tableInfo.name)")
@SwaggerScanClass
public class $!{tableName} {
/**
* 服務物件
*/
@Autowired
private $!{tableInfo.name}Service $!{serviceName};
/**
* 分頁查詢資料
*
* @param limitRequest 查詢實體
* @return 所有資料
*/
@PostMapping("/queryLimit")
public Resp<BaseLimitResponse<$!tableInfo.name>> selectAll(@RequestBody BaseLimitRequest<$!tableInfo.name> limitRequest) {
// 分頁查詢
IPage<$!tableInfo.name> page = this.$!{serviceName}.queryLimitPage(limitRequest);
// 封裝返回結果集
BaseLimitResponse<$!tableInfo.name> data = BaseLimitResponse.getInstance(page.getRecords(), page.getTotal(), page.getPages(), limitRequest.getPageIndex(), limitRequest.getPageSize());
return Resp.Ok(data);
}
/**
* 通過主鍵查詢單條資料
*
* @param id 主鍵
* @return 單條資料
*/
@GetMapping("/queryOne/{id}")
public Resp<$!tableInfo.name> selectOne(@PathVariable("id") Serializable id) {
return Resp.Ok(this.$!{serviceName}.getById(id));
}
/**
* 新增資料
*
* @param authLoginUser 實體物件
* @return 新增結果
*/
@PostMapping("/save")
public Resp<String> insert(@RequestBody $!tableInfo.name $!entityName) {
boolean save = false;
String executeMsg = null;
try {
save = this.$!{serviceName}.save($!entityName);
executeMsg = "新增成功,id 是:" + $!{entityName}.getId();
} catch (Exception e) {
executeMsg = e.getMessage();
}
return save ? Resp.Ok(executeMsg) : Resp.error(executeMsg);
}
/**
* 修改資料
*
* @param $!entityName 實體物件
* @return 修改結果
*/
@PutMapping("/update")
public Resp<String> update(@RequestBody $!tableInfo.name $!entityName) {
boolean update = false;
String executeMsg = null;
try {
update = this.$!{serviceName}.updateById($!entityName);
executeMsg = "修改成功,id 是:" + $!{entityName}.getId();
} catch (Exception e) {
executeMsg = e.getMessage();
}
return update ? Resp.Ok(executeMsg) : Resp.error(executeMsg);
}
/**
* 刪除資料
*
* @param idList 主鍵結合
* @return 刪除結果
*/
@DeleteMapping("/dels")
public Resp<String> delete(@RequestParam("idList") List<Long> idList) {
boolean delNumber = false;
String executeMsg = null;
try {
delNumber = this.$!{serviceName}.removeByIds(idList);
executeMsg = "刪除成功,ids 是:" + idList;
} catch (Exception e) {
executeMsg = e.getMessage();
}
return delNumber ? Resp.Ok(executeMsg) : Resp.error(executeMsg);
}
}
dao.java.vmCopy
##匯入巨集定義
$!{define.vm}
##設定表字尾(巨集定義)
#setTableSuffix("Mapper")
##儲存檔案(巨集定義)
#save("/mapper", "Mapper.java")
##包路徑(巨集定義)
#setPackageSuffix("mapper")
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import $!{tableInfo.savePackageName}.entity.$!tableInfo.name;
##表註釋(巨集定義)
#tableComment("表資料庫訪問層")
@Mapper
public interface $!{tableName} extends BaseMapper<$!tableInfo.name> {
}
entity.java.vmCopy
##匯入巨集定義
$!{define.vm}
##儲存檔案(巨集定義)
#save("/entity", ".java")
##包路徑(巨集定義)
#setPackageSuffix("entity")
##自動匯入包(全域性變數)
$!{autoImport.vm}
import lombok.Getter;
import lombok.Setter;
import lombok.experimental.Accessors;
import java.io.Serializable;
import io.swagger.annotations.ApiModel;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.annotation.TableField;
import io.swagger.annotations.ApiModelProperty;
import java.time.LocalDateTime;
import org.springframework.format.annotation.DateTimeFormat;
##表註釋(巨集定義)
#tableComment("表實體類")
@Getter
@Setter
@Accessors(chain = true)
@TableName("$!{tableInfo.name}")
@ApiModel(value = "$!{tableInfo.name}", description = "EasyCode")
public class $!{tableInfo.name} implements Serializable {
private static final long serialVersionUID = 1L;
#foreach($column in $tableInfo.fullColumn)
#if(${column.obj.name} == "id")
@TableId(value = "id", type = IdType.ASSIGN_ID)
#elseif(${column.obj.name} == "create_time")
@TableField(value = "create_time", fill = FieldFill.INSERT)
#elseif(${column.obj.name} == "update_time")
@TableField(value = "update_time", fill = FieldFill.INSERT_UPDATE)
#else
@TableField(value = "${column.obj.name}")
#end
@ApiModelProperty("${column.comment}")
#if($!{tool.getClsNameByFullName($column.type)} == "Date")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime $!{column.name};
#else
private $!{tool.getClsNameByFullName($column.type)} $!{column.name};
#end
#end
}
service.java.vm
##匯入巨集定義
$!{define.vm}
##設定表字尾(巨集定義)
#setTableSuffix("Service")
##儲存檔案(巨集定義)
#save("/service", "Service.java")
##包路徑(巨集定義)
#setPackageSuffix("service")
import com.baomidou.mybatisplus.extension.service.IService;
import $!{tableInfo.savePackageName}.entity.$!tableInfo.name;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.gton.io.BaseLimitRequest;
##表註釋(巨集定義)
#tableComment("表服務介面")
public interface $!{tableName} extends IService<$!tableInfo.name> {
/**
* Description: 分頁查詢
*
* @param limitRequest 分頁查詢引數
* @author: GuoTong
* @date: 2022-12-02 14:57:06
* @return:com.baomidou.mybatisplus.core.metadata.IPage
*/
IPage<$!tableInfo.name> queryLimitPage(BaseLimitRequest<$!tableInfo.name> limitRequest);
}
serviceImpl.java.vm
##匯入巨集定義
$!{define.vm}
##設定表字尾(巨集定義)
#setTableSuffix("ServiceImpl")
##儲存檔案(巨集定義)
#save("/service/impl", "ServiceImpl.java")
##包路徑(巨集定義)
#setPackageSuffix("service.impl")
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import $!{tableInfo.savePackageName}.mapper.$!{tableInfo.name}Mapper;
import $!{tableInfo.savePackageName}.entity.$!{tableInfo.name};
import $!{tableInfo.savePackageName}.service.$!{tableInfo.name}Service;
import org.springframework.stereotype.Service;
import com.alibaba.fastjson2.JSON;
import com.alibaba.fastjson2.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.gton.io.BaseLimitRequest;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import javax.annotation.Resource;
import java.time.LocalDateTime;
import java.util.Map;
import java.util.Objects;
##表註釋(巨集定義)
#tableComment("表服務實現類")
@Service("$!tool.firstLowerCase($tableInfo.name)Service")
public class $!{tableName} extends ServiceImpl<$!{tableInfo.name}Mapper, $!{tableInfo.name}> implements $!{tableInfo.name}Service {
@Autowired
private $!{tableInfo.name}Mapper $!tool.firstLowerCase($tableInfo.name)Mapper;
/**
* Description: 分頁查詢
*
* @param limitRequest 分頁查詢引數
* @author: GuoTong
* @date: 2022-12-02 14:57:06
* @return:com.baomidou.mybatisplus.core.metadata.IPage
*/
@Override
public IPage<$!{tableInfo.name}> queryLimitPage(BaseLimitRequest<$!{tableInfo.name}> limitRequest) {
$!{tableInfo.name} requestBody = limitRequest.getRequestBody();
long pageIndex = limitRequest.getPageIndex();
long pageSize = limitRequest.getPageSize();
IPage<$!{tableInfo.name}> page = new Page<>(pageIndex, pageSize);
QueryWrapper<$!{tableInfo.name}> queryWrapper = new QueryWrapper<>();
byte[] bytes = JSON.toJSONBytes(requestBody);
JSONObject thisObj = JSON.parseObject(bytes);
Set<Map.Entry<String, Object>> entries = thisObj.entrySet();
for (Map.Entry<String, Object> entry : entries) {
String key = entry.getKey();
StringBuilder column = new StringBuilder();
char[] chars = key.toCharArray();
for (char aChar : chars) {
if (Character.isUpperCase(aChar)) {
column.append("_");
}
column.append(aChar);
}
queryWrapper.eq(getValueIsBoolean(entry.getValue()), column.toString(), entry.getValue());
}
LocalDateTime beginTime = limitRequest.getBeginTime();
LocalDateTime endTime = limitRequest.getEndTime();
queryWrapper.ge(getValueIsBoolean(beginTime), "create_time", beginTime);
queryWrapper.le(getValueIsBoolean(endTime), "create_time", beginTime);
return $!{tool.firstLowerCase($tableInfo.name)}Mapper.selectPage(page, queryWrapper);
}
private boolean getValueIsBoolean(Object object) {
if (object instanceof String) {
return StringUtils.isNotEmpty((CharSequence) object);
}
return !Objects.isNull(object);
}
}
效果:
生成:
Controller檢視
package com.gton.auth.controller;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.gton.auth.entity.AuthLoginUser;
import com.gton.auth.service.AuthLoginUserService;
import com.gton.io.BaseLimitRequest;
import com.gton.io.BaseLimitResponse;
import com.gton.io.Resp;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.io.Serializable;
import java.util.List;
/**
* 統一認證中心使用者單(AuthLoginUser)表控制層
*
* @author 郭童
* @since 2022-12-02 14:27:50
*/
@RestController
@RequestMapping("authLoginUser")
public class AuthLoginUserController {
/**
* 服務物件
*/
@Resource
private AuthLoginUserService authLoginUserService;
/**
* 分頁查詢資料
*
* @param limitRequest 查詢實體
* @return 所有資料
*/
@PostMapping("/queryLimit")
public Resp<BaseLimitResponse<AuthLoginUser>> selectAll(@RequestBody BaseLimitRequest<AuthLoginUser> limitRequest) {
// 分頁查詢
IPage<AuthLoginUser> page = this.authLoginUserService.queryLimitPage(limitRequest);
// 封裝返回結果集
BaseLimitResponse<AuthLoginUser> data = BaseLimitResponse.getInstance(page.getRecords(), page.getTotal(), page.getPages(), limitRequest.getPageIndex(), limitRequest.getPageSize());
return Resp.Ok(data);
}
/**
* 通過主鍵查詢單條資料
*
* @param id 主鍵
* @return 單條資料
*/
@GetMapping("/queryOne/{id}")
public Resp<AuthLoginUser> selectOne(@PathVariable("id") Serializable id) {
return Resp.Ok(this.authLoginUserService.getById(id));
}
/**
* 新增資料
*
* @param authLoginUser 實體物件
* @return 新增結果
*/
@PostMapping
public Resp<String> insert(@RequestBody AuthLoginUser authLoginUser) {
boolean save = false;
String executeMsg = null;
try {
save = this.authLoginUserService.save(authLoginUser);
executeMsg = "新增成功,id 是:" + authLoginUser.getId();
} catch (Exception e) {
executeMsg = e.getMessage();
}
return save ? Resp.Ok(executeMsg) : Resp.error(executeMsg);
}
/**
* 修改資料
*
* @param authLoginUser 實體物件
* @return 修改結果
*/
@PutMapping
public Resp<String> update(@RequestBody AuthLoginUser authLoginUser) {
boolean update = false;
String executeMsg = null;
try {
update = this.authLoginUserService.updateById(authLoginUser);
executeMsg = "修改成功,id 是:" + authLoginUser.getId();
} catch (Exception e) {
executeMsg = e.getMessage();
}
return update ? Resp.Ok(executeMsg) : Resp.error(executeMsg);
}
/**
* 刪除資料
*
* @param idList 主鍵結合
* @return 刪除結果
*/
@DeleteMapping
public Resp<String> delete(@RequestParam("idList") List<Long> idList) {
boolean delNumber = false;
String executeMsg = null;
try {
delNumber = this.authLoginUserService.removeByIds(idList);
executeMsg = "刪除成功,ids 是:" + idList;
} catch (Exception e) {
executeMsg = e.getMessage();
}
return delNumber ? Resp.Ok(executeMsg) : Resp.error(executeMsg);
}
}