package org.ruoyi.core.mapper; import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.ObjectUtil; import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.reflect.GenericTypeUtils; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.toolkit.Db; import org.apache.ibatis.logging.Log; import org.apache.ibatis.logging.LogFactory; import org.ruoyi.common.core.utils.MapstructUtils; import org.ruoyi.common.core.utils.StreamUtils; import java.io.Serializable; import java.util.Collection; import java.util.List; import java.util.Map; import java.util.function.Function; /** * 自定义 Mapper 接口, 实现 自定义扩展 * * @param table 泛型 * @param vo 泛型 * @author Lion Li * @since 2021-05-13 */ @SuppressWarnings("unchecked") public interface BaseMapperPlus extends BaseMapper { Log log = LogFactory.getLog(BaseMapperPlus.class); /** * 获取当前实例对象关联的泛型类型 V 的 Class 对象 * * @return 返回当前实例对象关联的泛型类型 V 的 Class 对象 */ default Class currentVoClass() { return (Class) GenericTypeUtils.resolveTypeArguments(this.getClass(), BaseMapperPlus.class)[1]; } /** * 获取当前实例对象关联的泛型类型 T 的 Class 对象 * * @return 返回当前实例对象关联的泛型类型 T 的 Class 对象 */ default Class currentModelClass() { return (Class) GenericTypeUtils.resolveTypeArguments(this.getClass(), BaseMapperPlus.class)[0]; } /** * 使用默认的查询条件查询并返回结果列表 * * @return 返回查询结果的列表 */ default List selectList() { return this.selectList(new QueryWrapper<>()); } /** * 批量插入实体对象集合 * * @param entityList 实体对象集合 * @return 插入操作是否成功的布尔值 */ default boolean insertBatch(Collection entityList) { return Db.saveBatch(entityList); } /** * 批量根据ID更新实体对象集合 * * @param entityList 实体对象集合 * @return 更新操作是否成功的布尔值 */ default boolean updateBatchById(Collection entityList) { return Db.updateBatchById(entityList); } /** * 批量插入或更新实体对象集合 * * @param entityList 实体对象集合 * @return 插入或更新操作是否成功的布尔值 */ default boolean insertOrUpdateBatch(Collection entityList) { return Db.saveOrUpdateBatch(entityList); } /** * 批量插入实体对象集合并指定批处理大小 * * @param entityList 实体对象集合 * @param batchSize 批处理大小 * @return 插入操作是否成功的布尔值 */ default boolean insertBatch(Collection entityList, int batchSize) { return Db.saveBatch(entityList, batchSize); } /** * 批量根据ID更新实体对象集合并指定批处理大小 * * @param entityList 实体对象集合 * @param batchSize 批处理大小 * @return 更新操作是否成功的布尔值 */ default boolean updateBatchById(Collection entityList, int batchSize) { return Db.updateBatchById(entityList, batchSize); } /** * 批量插入或更新实体对象集合并指定批处理大小 * * @param entityList 实体对象集合 * @param batchSize 批处理大小 * @return 插入或更新操作是否成功的布尔值 */ default boolean insertOrUpdateBatch(Collection entityList, int batchSize) { return Db.saveOrUpdateBatch(entityList, batchSize); } /** * 根据ID查询单个VO对象 * * @param id 主键ID * @return 查询到的单个VO对象 */ default V selectVoById(Serializable id) { return selectVoById(id, this.currentVoClass()); } /** * 根据ID查询单个VO对象并将其转换为指定的VO类 * * @param id 主键ID * @param voClass 要转换的VO类的Class对象 * @param VO类的类型 * @return 查询到的单个VO对象,经过转换为指定的VO类后返回 */ default C selectVoById(Serializable id, Class voClass) { T obj = this.selectById(id); if (ObjectUtil.isNull(obj)) { return null; } return MapstructUtils.convert(obj, voClass); } /** * 根据ID集合批量查询VO对象列表 * * @param idList 主键ID集合 * @return 查询到的VO对象列表 */ default List selectVoByIds(Collection idList) { return selectVoByIds(idList, this.currentVoClass()); } /** * 根据ID集合批量查询实体对象列表,并将其转换为指定的VO对象列表 * * @param idList 主键ID集合 * @param voClass 要转换的VO类的Class对象 * @param VO类的类型 * @return 查询到的VO对象列表,经过转换为指定的VO类后返回 */ default List selectVoByIds(Collection idList, Class voClass) { List list = this.selectByIds(idList); if (CollUtil.isEmpty(list)) { return CollUtil.newArrayList(); } return MapstructUtils.convert(list, voClass); } /** * 根据查询条件Map查询VO对象列表 * * @param map 查询条件Map * @return 查询到的VO对象列表 */ default List selectVoByMap(Map map) { return selectVoByMap(map, this.currentVoClass()); } /** * 根据查询条件Map查询实体对象列表,并将其转换为指定的VO对象列表 * * @param map 查询条件Map * @param voClass 要转换的VO类的Class对象 * @param VO类的类型 * @return 查询到的VO对象列表,经过转换为指定的VO类后返回 */ default List selectVoByMap(Map map, Class voClass) { List list = this.selectByMap(map); if (CollUtil.isEmpty(list)) { return CollUtil.newArrayList(); } return MapstructUtils.convert(list, voClass); } /** * 根据条件查询单个VO对象 * * @param wrapper 查询条件Wrapper * @return 查询到的单个VO对象 */ default V selectVoOne(Wrapper wrapper) { return selectVoOne(wrapper, this.currentVoClass()); } /** * 根据条件查询单个VO对象,并根据需要决定是否抛出异常 * * @param wrapper 查询条件Wrapper * @param throwEx 是否抛出异常的标志 * @return 查询到的单个VO对象 */ default V selectVoOne(Wrapper wrapper, boolean throwEx) { return selectVoOne(wrapper, this.currentVoClass(), throwEx); } /** * 根据条件查询单个VO对象,并指定返回的VO对象的类型 * * @param wrapper 查询条件Wrapper * @param voClass 返回的VO对象的Class对象 * @param 返回的VO对象的类型 * @return 查询到的单个VO对象,经过类型转换为指定的VO类后返回 */ default C selectVoOne(Wrapper wrapper, Class voClass) { return selectVoOne(wrapper, voClass, true); } /** * 根据条件查询单个实体对象,并将其转换为指定的VO对象 * * @param wrapper 查询条件Wrapper * @param voClass 要转换的VO类的Class对象 * @param throwEx 是否抛出异常的标志 * @param VO类的类型 * @return 查询到的单个VO对象,经过转换为指定的VO类后返回 */ default C selectVoOne(Wrapper wrapper, Class voClass, boolean throwEx) { T obj = this.selectOne(wrapper, throwEx); if (ObjectUtil.isNull(obj)) { return null; } return MapstructUtils.convert(obj, voClass); } /** * 查询所有VO对象列表 * * @return 查询到的VO对象列表 */ default List selectVoList() { return selectVoList(new QueryWrapper<>(), this.currentVoClass()); } /** * 根据条件查询VO对象列表 * * @param wrapper 查询条件Wrapper * @return 查询到的VO对象列表 */ default List selectVoList(Wrapper wrapper) { return selectVoList(wrapper, this.currentVoClass()); } /** * 根据条件查询实体对象列表,并将其转换为指定的VO对象列表 * * @param wrapper 查询条件Wrapper * @param voClass 要转换的VO类的Class对象 * @param VO类的类型 * @return 查询到的VO对象列表,经过转换为指定的VO类后返回 */ default List selectVoList(Wrapper wrapper, Class voClass) { List list = this.selectList(wrapper); if (CollUtil.isEmpty(list)) { return CollUtil.newArrayList(); } return MapstructUtils.convert(list, voClass); } /** * 根据条件分页查询VO对象列表 * * @param page 分页信息 * @param wrapper 查询条件Wrapper * @return 查询到的VO对象分页列表 */ default

> P selectVoPage(IPage page, Wrapper wrapper) { return selectVoPage(page, wrapper, this.currentVoClass()); } /** * 根据条件分页查询实体对象列表,并将其转换为指定的VO对象分页列表 * * @param page 分页信息 * @param wrapper 查询条件Wrapper * @param voClass 要转换的VO类的Class对象 * @param VO类的类型 * @param

VO对象分页列表的类型 * @return 查询到的VO对象分页列表,经过转换为指定的VO类后返回 */ default > P selectVoPage(IPage page, Wrapper wrapper, Class voClass) { // 根据条件分页查询实体对象列表 List list = this.selectList(page, wrapper); // 创建一个新的VO对象分页列表,并设置分页信息 IPage voPage = new Page<>(page.getCurrent(), page.getSize(), page.getTotal()); if (CollUtil.isEmpty(list)) { return (P) voPage; } voPage.setRecords(MapstructUtils.convert(list, voClass)); return (P) voPage; } /** * 根据条件查询符合条件的对象,并将其转换为指定类型的对象列表 * * @param wrapper 查询条件Wrapper * @param mapper 转换函数,用于将查询到的对象转换为指定类型的对象 * @param 要转换的对象的类型 * @return 查询到的符合条件的对象列表,经过转换为指定类型的对象后返回 */ default List selectObjs(Wrapper wrapper, Function mapper) { return StreamUtils.toList(this.selectObjs(wrapper), mapper); } }