MybatisPlus拓展功能(内附全功能代码)

news/2024/10/18 8:19:18/

目录

代码生成

静态工具

案例

逻辑删除

枚举处理器

​编辑

Json处理器

分页插件功能

​编辑

案例

封装转换方法



代码生成

静态工具

案例

java">    @Overridepublic UserVO queryUserAndAddressById(long id) {
//        1.查询用户User user = getById(id);if (user == null || user.getStatus() == 2) {throw new RuntimeException("用户状态异常");}
//  2.查询地址
//        避免循环依赖List<Address> list = Db.lambdaQuery(Address.class).eq(Address::getUserId, id).list();UserVO userVO = new UserVO();BeanUtil.copyProperties(user, userVO);if (CollUtil.isNotEmpty(list)) {userVO.setAddresses(BeanUtil.copyToList(list, AddressVO.class));}//        2.查询地址return userVO;}
java">    @Overridepublic List<UserVO> queryUsersAndAddress(List<Long> ids) {List<User> users = listByIds(ids);if (CollUtil.isEmpty(users)) {return Collections.emptyList();}// 查询所有相关的地址列表,并按 userId 分组Map<Long, List<Address>> addressMap = Db.lambdaQuery(Address.class).in(Address::getUserId, ids).list().stream().collect(Collectors.groupingBy(Address::getUserId));// 使用 Stream API 转换 User 列表到 UserVO 列表,并关联地址信息return users.stream().map(user -> {UserVO userVO = new UserVO();BeanUtil.copyProperties(user, userVO); // 复制 User 属性到 UserVO// 使用 getOrDefault 避免 NullPointerException,并转换地址列表到 AddressVO 列表List<AddressVO> addresses = addressMap.getOrDefault(user.getId(), Collections.emptyList()).stream().map(address -> {AddressVO addressVO = new AddressVO();BeanUtil.copyProperties(address, addressVO); // 复制 Address 属性到 AddressVOreturn addressVO;}).collect(Collectors.toList());userVO.setAddresses(addresses); // 封装地址信息到 UserVOreturn userVO;}).collect(Collectors.toList());}

逻辑删除

枚举处理器

java">
@Getter
public enum UserStatus {NORMAL(1,"正常"),FROZEN(2,"冻结"),;@EnumValue@JsonValueprivate final int value;private final String desc;UserStatus(int value, String desc) {this.value = value;this.desc = desc;}
}

Json处理器

分页插件功能

java">@Configuration
public class MyBatisConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor(){
//        只有拦截功能MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
//        1.创建分页插件PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor(DbType.MYSQL);paginationInnerInterceptor.setMaxLimit(1000L);
//        2.添加分页插件interceptor.addInnerInterceptor(paginationInnerInterceptor);return interceptor;}
}

案例

java">    @Overridepublic PageDTO<UserVO> queryUsersPage(UserQuery query) {Page<User> page = new Page<>();// 创建分页对象if (query.getPageNo()!=null|| query.getPageSize()!=null){page.setPages(query.getPageNo());page.setSize(query.getPageSize());}// 添加排序,根据 query.getIsAsc() 的值确定升序或降序if (query.getIsAsc()) {page.addOrder(OrderItem.asc("balance")); // 升序} else {page.addOrder(OrderItem.desc("balance")); // 降序}// 创建查询条件LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();if (StrUtil.isNotEmpty(query.getName())) {queryWrapper.like(User::getUsername, query.getName());}queryWrapper.eq(User::getStatus, UserStatus.NORMAL);Page<User>  page1= userMapper.selectPage(page, queryWrapper);PageDTO<UserVO> pageDTO = new PageDTO<>();pageDTO.setList(BeanUtil.copyToList(page1.getRecords(), UserVO.class));
//        总条数pageDTO.setTotal(page1.getTotal());
//        总页数pageDTO.setPages(page1.getPages());// 执行分页查询并返回结果return pageDTO;}

封装转换方法

java">@Data
@ApiModel(description = "分页查询实体")
public class PageQuery {@ApiModelProperty("页码")private Integer pageNo=1;@ApiModelProperty("页码")private Integer pageSize=5;@ApiModelProperty("排序字段")private String sortBy;@ApiModelProperty("是否升序")private Boolean isAsc=true;public <T>  Page<T> toMpPage(OrderItem ... orders){// 1.分页条件Page<T> p = Page.of(pageNo, pageSize);// 2.排序条件// 2.1.先看前端有没有传排序字段if (sortBy != null) {p.addOrder(new OrderItem(sortBy, isAsc));return p;}// 2.2.再看有没有手动指定排序字段if(orders != null){
//            传递可变参数p.addOrder(orders);}return p;}public <T> Page<T> toMpPage(String defaultSortBy, boolean isAsc){return this.toMpPage(new OrderItem(defaultSortBy, isAsc));}public <T> Page<T> toMpPageDefaultSortByCreateTimeDesc() {return toMpPage("create_time", false);}public <T> Page<T> toMpPageDefaultSortByUpdateTimeDesc() {return toMpPage("update_time", false);}
}

java">
@Data
@NoArgsConstructor
@AllArgsConstructor
@ApiModel(description = "分页结果")
public class PageDTO<V> {@ApiModelProperty("总条数")private Long total;@ApiModelProperty("总页数")private Long pages;@ApiModelProperty("集合")private List<V> list;/*** 返回空分页结果* @param p MybatisPlus的分页结果* @param <V> 目标VO类型* @param <P> 原始PO类型* @return VO的分页对象*/
//   类上的泛型是属于对象的,静态方法不能调用public static <V, P> PageDTO<V> empty(Page<P> p){return new PageDTO<>(p.getTotal(), p.getPages(), Collections.emptyList());}/*** 将MybatisPlus分页结果转为 VO分页结果* @param p MybatisPlus的分页结果* @param voClass 目标VO类型的字节码* @param <V> 目标VO类型* @param <P> 原始PO类型* @return VO的分页对象*/
//    调用者才能知道字节码是什么,泛型不能获取classpublic static <V, P> PageDTO<V> of(Page<P> p, Class<V> voClass) {// 1.非空校验List<P> records = p.getRecords();if (records == null || records.size() <= 0) {// 无数据,返回空结果return empty(p);}// 2.数据转换List<V> vos = BeanUtil.copyToList(records, voClass);// 3.封装返回return new PageDTO<>(p.getTotal(), p.getPages(), vos);}/*** 将MybatisPlus分页结果转为 VO分页结果,允许用户自定义PO到VO的转换方式* @param p MybatisPlus的分页结果* @param convertor PO到VO的转换函数* @param <V> 目标VO类型* @param <P> 原始PO类型* @return VO的分页对象*/
//    函数式编程public static <V, P> PageDTO<V> of(Page<P> p, Function<P, V> convertor) {// 1.非空校验List<P> records = p.getRecords();if (records == null || records.size() <= 0) {// 无数据,返回空结果return empty(p);}// 2.数据转换List<V> vos = records.stream().map(convertor).collect(Collectors.toList());// 3.封装返回return new PageDTO<>(p.getTotal(), p.getPages(), vos);}
}

http://www.ppmy.cn/news/1461933.html

相关文章

UIKit之图片浏览器

功能需求 实现一个图片浏览器&#xff0c;点击左右按钮可以切换背景图&#xff0c;且更新背景图对应的索引页和图片描述内容。 分析&#xff1a; 实现一个UIView的子类即可&#xff0c;该子类包含多个按钮。 实现步骤&#xff1a; 使用OC语言&#xff0c;故创建cocoa Touch类…

ANSYS Maxwell16 引导

Maxwell 使用 下载 https://download.csdn.net/download/wangjun_huster/89313272 安装 https://www.52txr.cn/2022/MaxwellInstall.html 入门

用Java爬虫解决问题:探索网络数据的奥秘

网络爬虫是一种用于自动获取互联网信息的程序&#xff0c;常用于搜索引擎、数据挖掘等领域。本文将介绍如何使用Java编写网络爬虫来解决问题&#xff0c;并提供具体的代码实现及测试&#xff0c;帮助读者掌握爬虫技术并应用于实际项目中。 1. 爬虫原理 爬虫通过模拟人类浏览器…

一文了解Python跨包引用其他模块

在Python中&#xff0c;跨包引用其他模块主要涉及到Python的模块导入机制以及包&#xff08;package&#xff09;的概念。包是Python中用来组织模块的方式&#xff0c;它是一个包含多个模块的文件夹&#xff0c;该文件夹下必须有一个__init__.py文件&#xff08;在Python 3.3之…

01.认识HTML及常用标签

目录 URL&#xff08;统一资源定位系统&#xff09; HTML&#xff08;超文本标记语言&#xff09; 1&#xff09;html标签 2&#xff09;head标签 3&#xff09;title标签 4&#xff09;body标签 标签的分类 DTD文档声明 基础标签 1&#xff09;H系列标签 2&#xff09…

虚幻五关卡制作学习笔记

1.创建一个移动平台 这个移动平台的功能&#xff1a;从箭头1移动到箭头2来回移动&#xff0c;可移动时发绿光&#xff0c;不可移动时发红光 首先&#xff0c;创建两个材质&#xff0c;发红光和绿光 然后我们创建一个actor蓝图类&#xff0c;添加两个arrow组件&#xff0c;两个…

STK中的光照计算模型

本文简要阐述STK中光照计算的模型。 在航天任务中&#xff0c;通常需要分析地面站、飞行器在一定时间内的光照情况&#xff0c;具体包括&#xff1a; 地面站处在光照区和阴影区的具体时间范围&#xff1b;考虑地形遮挡后&#xff0c;地面站的光照区和阴影区的变化情况&#x…

QT设计模式:模板模式

基本概念 模板模式&#xff08;Template Pattern&#xff09;是一种行为型设计模式&#xff0c;它定义了一个操作中的算法的模板&#xff0c;而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重新定义该算法的某些特定步骤。 实现的模块有&#xff1…