Mybatis-plus自定义BaseMapper文件

Mybatis-plus自定义BaseMapper文件

这里主要是介绍通过MyBatis-Plus使用自定义继承 baseMapper 扩展指定返回VO类型等,方便以后查阅!!!

自定义CustomBaseMapper文件

package com.wl.cloud.core.mybatis;import cn.hutool.core.bean.BeanUtil;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Constants;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.apache.ibatis.annotations.Param;
import org.springframework.util.ObjectUtils;import java.io.Serializable;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;/*** @author: wanglin* @date: 2023-12-18 周一* @Version: 1.0* @Description:*/
public interface CustomBaseMapper<T> extends BaseMapper<T> {
//    Log log = LogFactory.getLog(CustomBaseMapper.class);/*** 根据 ID 查询** @param kClass vo类型* @param id     主键ID*/default <K> K getVoById(Serializable id, Class<K> kClass) {T t = selectById(id);return ObjectUtils.isEmpty(t) ? null : BeanUtil.toBean(t, kClass);}/*** 根据 ID 查询** @param id        主键ID* @param convertor 转换函数* @param <K>       vo类型*/default <K> K getVoById(Serializable id, Function<T, K> convertor) {T t = selectById(id);return ObjectUtils.isEmpty(t) ? null : convertor.apply(t);}/*** 查询(根据ID 批量查询)** @param kClass vo类型* @param idList 主键ID列表*/default <K> List<K> listVoByIds(Collection<? extends Serializable> idList, Class<K> kClass) {List<T> list = selectBatchIds(idList);if (list == null) {return null;}return list.stream().map(any -> BeanUtil.toBean(any, kClass)).collect(Collectors.toList());}/*** 查询(根据ID 批量查询)** @param convertor 转换函数* @param idList    主键ID列表*/default <K> List<K> listVoByIds(Collection<? extends Serializable> idList, Function<Collection<T>, List<K>> convertor) {List<T> list = selectBatchIds(idList);if (list == null) {return null;}return convertor.apply(list);}/*** 查询(根据 columnMap 条件)** @param kClass    vo类型* @param columnMap 表字段 map 对象*/default <K> List<K> listVoByMap(Map<String, Object> columnMap, Class<K> kClass) {List<T> list = selectByMap(columnMap);if (list == null) {return null;}return list.stream().map(any -> BeanUtil.toBean(any, kClass)).collect(Collectors.toList());}/*** 查询(根据 columnMap 条件)** @param convertor 转换函数* @param columnMap 表字段 map 对象*/default <K> List<K> listVoByMap(Map<String, Object> columnMap, Function<Collection<T>, List<K>> convertor) {List<T> list = selectByMap(columnMap);if (list == null) {return null;}return convertor.apply(list);}//    /**
//     * 根据 Wrapper,查询一条记录
//     *
//     * @param queryWrapper 实体对象封装操作类
//     * @param throwEx      有多个 result 是否抛出异常
//     */
//    default T getOne(Wrapper<T> queryWrapper, boolean throwEx) {
//        if (throwEx) {
//            return selectOne(queryWrapper);
//        }
//        return SqlHelper.getObject(log, selectList(queryWrapper));
//    }
//
//    /**
//     * 根据 Wrapper,查询一条记录 <br/>
//     * <p>结果集,如果是多个会抛出异常,随机取一条加上限制条件 wrapper.last("LIMIT 1")</p>
//     *
//     * @param kClass       vo类型
//     * @param queryWrapper 实体对象封装操作类
//     */
//    default <K> K getVoOne(Wrapper<T> queryWrapper, Class<K> kClass) {
//        return BeanUtil.toBean(getOne(queryWrapper, true), kClass);
//    }
//
//    /**
//     * 根据 Wrapper,查询一条记录 <br/>
//     * <p>结果集,如果是多个会抛出异常,随机取一条加上限制条件 wrapper.last("LIMIT 1")</p>
//     *
//     * @param convertor    转换函数
//     * @param queryWrapper 实体对象封装操作类
//     */
//    default <K> K getVoOne(Wrapper<T> queryWrapper, Function<T, K> convertor) {
//        return convertor.apply(getOne(queryWrapper, true));
//    }/*** 根据 Wrapper,查询一条记录 <br/>* <p>结果集,如果是多个会抛出异常,随机取一条加上限制条件 wrapper.last("LIMIT 1")</p>** @param kClass       vo类型* @param queryWrapper 实体对象封装操作类*/default <K> K getVoOne(Wrapper<T> queryWrapper, Class<K> kClass) {T t = selectOne(queryWrapper);return ObjectUtils.isEmpty(t) ? null : BeanUtil.toBean(t, kClass);}/*** 根据 Wrapper,查询一条记录 <br/>* <p>结果集,如果是多个会抛出异常,随机取一条加上限制条件 wrapper.last("LIMIT 1")</p>** @param convertor    转换函数* @param queryWrapper 实体对象封装操作类*/default <K> K getVoOne(Wrapper<T> queryWrapper, Function<T, K> convertor) {T t = selectOne(queryWrapper);return ObjectUtils.isEmpty(t) ? null : convertor.apply(t);}/*** 查询列表* 根据给定的查询条件,查询并返回一个实体对象列表的VO(值对象)形式。** @param kClass       VO类型的Class对象,用于指定返回列表的元素类型。* @param queryWrapper 用于封装查询条件的实体对象。* @return 返回一个转换后的VO类型列表。如果查询结果为空,则返回null。*/default <K> List<K> listVo(Wrapper<T> queryWrapper, Class<K> kClass) {List<T> list = selectList(queryWrapper);if (list == null) {return null;}return list.stream().map(any -> BeanUtil.toBean(any, kClass)).collect(Collectors.toList());}/*** 查询列表,并转换成目标类型** @param queryWrapper 用于构建查询条件的实体对象封装操作类* @param convertor    将查询结果集合转换成目标类型集合的函数* @param <K>          目标类型* @return 转换后的目标类型集合。如果查询结果为null,则返回null。*/default <K> List<K> listVo(Wrapper<T> queryWrapper, Function<Collection<T>, List<K>> convertor) {List<T> list = selectList(queryWrapper);if (list == null) {return null;}return convertor.apply(list);}/*** 查询所有实体列表** @param kClass 需要查询的实体类的Class对象* @param <K>    实体类的类型* @return 返回一个包含所有实体的列表*/default <K> List<K> listVo(Class<K> kClass) {return listVo(Wrappers.emptyWrapper(), kClass);}/*** 查询所有** @param convertor* @param <K>* @return*/default <K> List<K> listVo(Function<Collection<T>, List<K>> convertor) {return listVo(Wrappers.emptyWrapper(), convertor);}/*** 根据 entity 条件,查询全部记录(并翻页)* *** @param page         分页查询条件(可以为 RowBounds.DEFAULT)* @param queryWrapper 实体对象封装操作类(可以为 null)* @param kClass* @param <E>* @param <K>          vo类型* @return*/default <E extends IPage<T>, K> IPage<K> pageVo(E page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper, Class<K> kClass) {IPage<T> result = selectPage(page, queryWrapper);IPage pageVo = new Page();if (result.getTotal() == 0) {return pageVo;}BeanUtil.copyProperties(result, pageVo);List<K> voList = result.getRecords().stream().map(e -> BeanUtil.toBean(e, kClass)).collect(Collectors.toList());pageVo.setRecords(voList);`在这里插入代码片`return pageVo;}/*** 新增方法: 批量插入** @param batchList* @return*/int insertBatch(@Param("list") Collection<T> batchList);
}

使用示例

@Service
public class PersonTestServiceImpl implements PersonTestService {@Autowiredprivate PersonTestMapper personTestMapper;@Transactional(readOnly = true)@Overridepublic DataStoreDTO<PersonTestVO> page(Pageable pageable, PersonTestQueryDTO queryDto) {QueryWrapper<PersonTest> queryWrapper = this.buildQuery(queryDto);Page<PersonTest> page = PageUtils.transferPage(pageable);IPage<PersonTestVO> result = this.personTestMapper.pageVo(page, queryWrapper, PersonTestVO.class);return new DataStoreDTO(result.getTotal(), result.getRecords());}@Transactional(readOnly = true)@Overridepublic List<PersonTestVO> list(Sort sort, PersonTestQueryDTO queryDto) {QueryWrapper<PersonTest> queryWrapper = this.buildQuery(queryDto);PageUtils.transferSort(queryWrapper, sort);List<PersonTestVO> voList = this.personTestMapper.listVo(queryWrapper, PersonTestVO.class);return voList;}@Transactional(rollbackFor = Exception.class)@Overridepublic void delete(Set<String> ids) {if (CollectionUtils.isNotEmpty(ids)) {personTestMapper.deleteBatchIds(ids);}}@Transactional(readOnly = true)@Overridepublic PersonTestVO get(String id) {Assert.hasText(id, "id不能为空");PersonTestVO vo = personTestMapper.getVoById(id, PersonTestVO.class);Assert.notNull(vo, "找不到id为 " + id + " 的记录");return vo;}
}

关注林哥,持续更新哦!!!★,°:.☆( ̄▽ ̄)/$:.°★ 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/817238.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker run启动一个开发备忘清单速查表 —— 筑梦之路

docker run -itd --name reference -p 3000:3000 registry.cn-beijing.aliyuncs.com/deanmr/reference:latest包含&#xff1a;运维&#xff0c;前端&#xff0c;后端&#xff0c;工具&#xff0c;命令&#xff0c;数据库 部分截图展示&#xff1a;

【Bugku】sqli-0x1

1.打开靶场&#xff0c;进入实验场景 2.按F12查看源代码&#xff0c;发现有一个/?pls_help路径&#xff0c;在url后加上查看。 3.得到的php源码 首先&#xff0c;代码通过 error_reporting(0) 和 error_log(0) 关闭了错误报告&#xff0c;这可以防止攻击者从错误信息中获取敏…

SpringBoot实用开发(十四)-- 消息(Message)的简单认识

目录 1.消息的概念 2.Java处理消息的标准规范 3.JMS 4.AMQP 5.MQTT 1.消息的概念 广义角度来说,消息其实就是信息,但是和信息又有所不同。信息通常被定义为一组数据,而消息除了具有数据的特征之外,还有

数据结构-加解密算法

引言 加解密算法是信息安全领域的重要组成部分&#xff0c;它们用于保护数据的机密性、完整性和可用性。 对称加密算法 对称加密算法使用相同的密钥进行加密和解密。 特性&#xff1a; 加密和解密速度快&#xff0c;适合处理大量数据。 优点&#xff1a; 效率高&#xf…

设计模式之大话西游

8年前深究设计模式&#xff0c;现如今再次回锅&#xff5e; 还是大话设计模式 这本书还是可以的 大话西游经典的台词&#xff1a;“曾经有一份真挚的爱情摆在我面前,我没有珍惜,等我失去的时候,我才后悔莫及,人世间最痛苦的事莫过于此。如果上天能够给我一个再来一次的机会,我会…

【每周精选资讯 | 第 5 期】2024-04-08 ~ 2024-04-14

文章目录 前言内容百度智能云发布干帆大模型一体机&#xff0c;加速企业私有化部署大模型北大开源 aiXcoder-7B 代码大模型&#xff0c;专为企业私有部署设计WPS AI 企业版发布&#xff1a;多个大模型自由切换英特尔发布 AI 芯片 Gaudi 3&#xff0c;称性能超越英伟达 H100马云…

国外站群服务器有哪几种?

国外站群服务器种类繁多&#xff0c;它们各具特色&#xff0c;适用于不同的业务需求和场景。以下将为您科普几种常见的国外站群服务器及其特点。 首先&#xff0c;美国站群服务器以其丰富的IP资源和强大的网络技术著称。作为全球网络技术和数据中心发展的领先者&#xff0c;美国…

leetcode705-Design HashSet

题目 不使用任何内建的哈希表库设计一个哈希集合&#xff08;HashSet&#xff09;。 实现 MyHashSet 类&#xff1a; void add(key) 向哈希集合中插入值 key 。 bool contains(key) 返回哈希集合中是否存在这个值 key 。 void remove(key) 将给定值 key 从哈希集合中删除。如果…

LlamaIndex 文档3

文章目录 一、使用 LLamaIndex 构建全栈 Web 应用程序的指南1、Flask 后端基本 Flask - 处理用户索引查询Advanced Flask - 处理用户文档上传 2、React 前端获取文档.tsx查询索引.tsx插入文档.tsx所有其他前端优点 3、结论 二、使用 Delphic 构建全栈 LlamaIndex Web 应用程序的…

数据库SQL语言实战(二)

目录 检索查询 题目一 题目二 题目三 题目四 题目五 题目六 题目七 题目八 题目九&#xff08;本篇最难的题目&#xff09; 分析 实现&#xff08;两种方式&#xff09; 模板 总结 检索查询 按照要求查找数据库中的数据 题目一 找出没有选修任何课程的学…

redis 存放 redis 不同list集合 不同对象取值 list集合

redis 存放 redis 不同list集合 不同对象取值 list集合 测试代码 List<User> userList new ArrayList<>();userList ArrayListConstants.getUserSql;//查询 list 集合数据RedisTemplateUtil.setRedisList("keyredis", userList);//set 集合数据RedisTem…

Redis 模糊key查询

Redis 提供了两种主要的方式来执行模糊查询Key的操作&#xff1a; 方法1&#xff1a;KEYS 命令 1KEYS pattern KEYS 命令允许你按照给定的模式来查找数据库中的所有匹配项。例如&#xff1a; 1redis> KEYS user* 这条命令会返回所有以 "user" 开头的key。 然…

YesPMP众包平台 | 活动有礼,现金奖励点击领取!

YesPMP众包平台在线发福利啦&#xff0c;4月16日活动火热开启&#xff0c;现金奖励等你来领&#xff0c;最高可领千元&#xff0c;赶快参与将奖励收入囊中&#xff0c;一起来了解活动细节吧&#xff01; 一、活动内容&#xff1a; 活动一&#xff1a;【项目征集令】活动&…

Python Flask-Security- 构建安全而强大的Web应用

Flask-Security是一个基于Flask的安全扩展&#xff0c;为开发者提供了构建安全且强大的Web应用的工具。本文将深入探讨Flask- Security的核心功能、基本用法以及在实际应用中的一些高级特性&#xff0c;通过丰富的示例代码&#xff0c;助您更全面地了解和应用这一用于Web应用安…

2024年【危险化学品经营单位主要负责人】考试题库及危险化学品经营单位主要负责人新版试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 危险化学品经营单位主要负责人考试题库是安全生产模拟考试一点通总题库中生成的一套危险化学品经营单位主要负责人新版试题&#xff0c;安全生产模拟考试一点通上危险化学品经营单位主要负责人作业手机同步练习。2024…

python+playwright 学习-88 禁止加载图片等资源

前言 对于爬虫的小伙伴来说,有时候只需抓取页面的文本,不用加载图片,可以加快操作页面速度,那么我们可以设置禁止加载图片等资源。 禁止图片加载 根据url地址的后缀,图片资源后缀一般是png,jpg,jpeg,gif等格式。 from playwright.sync_api import sync_playwrightwith…

vue3自定义多个v-model以及自定义修饰符

从 Vue 3.4 开始&#xff0c;推荐的实现方式是使用 defineModel() 宏&#xff1a; 废话不多说&#xff0c;直接上代码 <!-- Son.vue --> <script setup> const model defineModel() </script><template><span>My input</span> <inpu…

【数仓】DataX 通过SpringBoot项目自动生成 job.json 文件

相关文章 【数仓】基本概念、知识普及、核心技术【数仓】数据分层概念以及相关逻辑【数仓】Hadoop软件安装及使用&#xff08;集群配置&#xff09;【数仓】Hadoop集群配置常用参数说明【数仓】zookeeper软件安装及集群配置【数仓】kafka软件安装及集群配置【数仓】flume软件安…

Gradle 实战 - 插件-ApiHug准备-工具篇-015

&#x1f917; ApiHug {Postman|Swagger|Api...} 快↑ 准√ 省↓ GitHub - apihug/apihug.com: All abou the Apihug apihug.com: 有爱&#xff0c;有温度&#xff0c;有质量&#xff0c;有信任ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplace ApiHug …

Unity WebGL 2021 Release-Notes

&#x1f308;WebGL 2021 Release-Notes 版本更新内容2021.3.33WebGL: Fixed a bug that caused for input to not be released when focus was removed from canvas on Windows Chrome.(UUM-53519)2021.3.33WebGL: Fixed the bug that caused for an error to be thrown when …