From 90d4fd8cf1db71cf51cfc2694290a9a4bc53344e Mon Sep 17 00:00:00 2001
From: 疯狂的狮子li <15040126243@163.com>
Date: 星期六, 24 七月 2021 21:19:05 +0800
Subject: [PATCH] update [重大改动] 重写VO转换 支持深拷贝 将VO类抽象到 ServicePlus 泛型处理

---
 ruoyi-common/src/main/java/com/ruoyi/common/core/mybatisplus/core/IServicePlus.java |  303 ++++++++++++++-----------------------------------
 1 files changed, 88 insertions(+), 215 deletions(-)

diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/core/mybatisplus/core/IServicePlus.java b/ruoyi-common/src/main/java/com/ruoyi/common/core/mybatisplus/core/IServicePlus.java
index 21b0ecc..e2d9a3d 100644
--- a/ruoyi-common/src/main/java/com/ruoyi/common/core/mybatisplus/core/IServicePlus.java
+++ b/ruoyi-common/src/main/java/com/ruoyi/common/core/mybatisplus/core/IServicePlus.java
@@ -1,6 +1,6 @@
 package com.ruoyi.common.core.mybatisplus.core;
 
-import cn.hutool.core.bean.BeanUtil;
+import cn.hutool.core.bean.copier.CopyOptions;
 import com.baomidou.mybatisplus.core.conditions.Wrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.IService;
@@ -11,7 +11,6 @@
 import java.util.List;
 import java.util.Map;
 import java.util.function.Function;
-import java.util.stream.Collectors;
 
 /**
  * 鑷畾涔� Service 鎺ュ彛, 瀹炵幇 鏁版嵁搴撳疄浣撲笌 vo 瀵硅薄杞崲杩斿洖
@@ -19,225 +18,99 @@
  * @author Lion Li
  * @since 2021-05-13
  */
-public interface IServicePlus<T> extends IService<T> {
+public interface IServicePlus<T, K> extends IService<T> {
 
-    /**
-     * 鏍规嵁 ID 鏌ヨ
-     *
-     * @param kClass vo绫诲瀷
-     * @param id     涓婚敭ID
-     */
-    default <K> K getVoById(Serializable id, Class<K> kClass) {
-        T t = getBaseMapper().selectById(id);
-        return BeanUtil.toBean(t, kClass);
-    }
+	K getVoById(Serializable id, CopyOptions copyOptions);
 
-    /**
-     * 鏍规嵁 ID 鏌ヨ
-     *
-     * @param id        涓婚敭ID
-     * @param convertor 杞崲鍑芥暟
-     * @param <K>       vo绫诲瀷
-     */
-    default <K> K getVoById(Serializable id, Function<T, K> convertor) {
-        T t = getBaseMapper().selectById(id);
-        return convertor.apply(t);
-    }
-
-    /**
-     * 鏌ヨ锛堟牴鎹甀D 鎵归噺鏌ヨ锛�
-     *
-     * @param kClass vo绫诲瀷
-     * @param idList 涓婚敭ID鍒楄〃
-     */
-    default <K> List<K> listVoByIds(Collection<? extends Serializable> idList, Class<K> kClass) {
-        List<T> list = getBaseMapper().selectBatchIds(idList);
-        if (list == null) {
-            return null;
-        }
-        return list.stream()
-                .map(any -> BeanUtil.toBean(any, kClass))
-                .collect(Collectors.toList());
-    }
-
-    /**
-     * 鏌ヨ锛堟牴鎹甀D 鎵归噺鏌ヨ锛�
-     *
-     * @param convertor 杞崲鍑芥暟
-     * @param idList    涓婚敭ID鍒楄〃
-     */
-    default <K> List<K> listVoByIds(Collection<? extends Serializable> idList,
-                                    Function<Collection<T>, List<K>> convertor) {
-        List<T> list = getBaseMapper().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 = getBaseMapper().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 = getBaseMapper().selectByMap(columnMap);
-        if (list == null) {
-            return null;
-        }
-        return convertor.apply(list);
-    }
-
-    /**
-     * 鏍规嵁 Wrapper锛屾煡璇竴鏉¤褰� <br/>
-     * <p>缁撴灉闆嗭紝濡傛灉鏄涓細鎶涘嚭寮傚父锛岄殢鏈哄彇涓�鏉″姞涓婇檺鍒舵潯浠� wrapper.last("LIMIT 1")</p>
-     *
-     * @param kClass       vo绫诲瀷
-     * @param queryWrapper 瀹炰綋瀵硅薄灏佽鎿嶄綔绫� {@link com.baomidou.mybatisplus.core.conditions.query.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 瀹炰綋瀵硅薄灏佽鎿嶄綔绫� {@link com.baomidou.mybatisplus.core.conditions.query.QueryWrapper}
-     */
-    default <K> K getVoOne(Wrapper<T> queryWrapper, Function<T, K> convertor) {
-        return convertor.apply(getOne(queryWrapper, true));
-    }
-
-    /**
-     * 鏌ヨ鍒楄〃
-     *
-     * @param kClass       vo绫诲瀷
-     * @param queryWrapper 瀹炰綋瀵硅薄灏佽鎿嶄綔绫� {@link com.baomidou.mybatisplus.core.conditions.query.QueryWrapper}
-     */
-    default <K> List<K> listVo(Wrapper<T> queryWrapper, Class<K> kClass) {
-        List<T> list = getBaseMapper().selectList(queryWrapper);
-        if (list == null) {
-            return null;
-        }
-        return list.stream()
-                .map(any -> BeanUtil.toBean(any, kClass))
-                .collect(Collectors.toList());
-    }
-
-    /**
-     * 鏌ヨ鍒楄〃
-     *
-     * @param convertor    杞崲鍑芥暟
-     * @param queryWrapper 瀹炰綋瀵硅薄灏佽鎿嶄綔绫� {@link com.baomidou.mybatisplus.core.conditions.query.QueryWrapper}
-     */
-    default <K> List<K> listVo(Wrapper<T> queryWrapper, Function<Collection<T>, List<K>> convertor) {
-        List<T> list = getBaseMapper().selectList(queryWrapper);
-        if (list == null) {
-            return null;
-        }
-        return convertor.apply(list);
-    }
-
-    /**
-     * 鏌ヨ鎵�鏈�
-     *
-     * @param kClass vo绫诲瀷
-     * @see Wrappers#emptyWrapper()
-     */
-    default <K> List<K> listVo(Class<K> kClass) {
-        return listVo(Wrappers.emptyWrapper(), kClass);
-    }
-
-    /**
-     * 鏌ヨ鎵�鏈�
-     *
-     * @param convertor 杞崲鍑芥暟
-     * @see Wrappers#emptyWrapper()
-     */
-    default <K> List<K> listVo(Function<Collection<T>, List<K>> convertor) {
-        return listVo(Wrappers.emptyWrapper(), convertor);
-    }
-
-    /**
-     * 缈婚〉鏌ヨ
-     *
-     * @param page         缈婚〉瀵硅薄
-     * @param queryWrapper 瀹炰綋瀵硅薄灏佽鎿嶄綔绫�
-     */
-    default <K> PagePlus<T, K> pageVo(PagePlus<T, K> page, Wrapper<T> queryWrapper, Class<K> kClass) {
-        PagePlus<T, K> result = getBaseMapper().selectPage(page, queryWrapper);
-        List<K> volist = result.getRecords().stream()
-                .map(any -> BeanUtil.toBean(any, kClass))
-                .collect(Collectors.toList());
-        result.setRecordsVo(volist);
-        return result;
-    }
-
-    /**
-     * 缈婚〉鏌ヨ
-     *
-     * @param page         缈婚〉瀵硅薄
-     * @param queryWrapper 瀹炰綋瀵硅薄灏佽鎿嶄綔绫�
-     * @param convertor    杞崲鍑芥暟
-     */
-    default <K> PagePlus<T, K> pageVo(PagePlus<T, K> page, Wrapper<T> queryWrapper,
-                                      Function<Collection<T>, List<K>> convertor) {
-        PagePlus<T, K> result = getBaseMapper().selectPage(page, queryWrapper);
-        return result.setRecordsVo(convertor.apply(result.getRecords()));
-    }
-
-    /**
-     * 鏃犳潯浠剁炕椤垫煡璇�
-     *
-     * @param page   缈婚〉瀵硅薄
-     */
-    default <K> PagePlus<T, K> pageVo(PagePlus<T, K> page, Class<K> kClass) {
-        return pageVo(page, Wrappers.emptyWrapper(), kClass);
-    }
-
-    /**
-     * 鏃犳潯浠剁炕椤垫煡璇�
-     *
-     * @param page      缈婚〉瀵硅薄
-     * @param convertor 杞崲鍑芥暟
-     */
-    default <K> PagePlus<T, K> pageVo(PagePlus<T, K> page, Function<Collection<T>, List<K>> convertor) {
-        return pageVo(page, Wrappers.emptyWrapper(), convertor);
-    }
-
-	@Override
-	default boolean saveBatch(Collection<T> entityList) {
-		return saveBatch(entityList, DEFAULT_BATCH_SIZE);
+	default K getVoById(Serializable id) {
+		return getVoById(id, new CopyOptions());
 	}
 
-	@Override
-	default boolean saveOrUpdateBatch(Collection<T> entityList) {
-		return saveOrUpdateBatch(entityList, DEFAULT_BATCH_SIZE);
+	default K getVoById(Serializable id, Function<T, K> convertor) {
+		return convertor.apply(getById(id));
 	}
 
-	@Override
-	default boolean updateBatchById(Collection<T> entityList) {
-		return updateBatchById(entityList, DEFAULT_BATCH_SIZE);
+	List<K> listVoByIds(Collection<? extends Serializable> idList, CopyOptions copyOptions);
+
+	default List<K> listVoByIds(Collection<? extends Serializable> idList) {
+		return listVoByIds(idList, new CopyOptions());
+	}
+
+	default List<K> listVoByIds(Collection<? extends Serializable> idList,
+								Function<Collection<T>, List<K>> convertor) {
+		List<T> list = getBaseMapper().selectBatchIds(idList);
+		if (list == null) {
+			return null;
+		}
+		return convertor.apply(list);
+	}
+
+	List<K> listVoByMap(Map<String, Object> columnMap, CopyOptions copyOptions);
+
+	default List<K> listVoByMap(Map<String, Object> columnMap) {
+		return listVoByMap(columnMap, new CopyOptions());
+	}
+
+
+	default List<K> listVoByMap(Map<String, Object> columnMap,
+								Function<Collection<T>, List<K>> convertor) {
+		List<T> list = getBaseMapper().selectByMap(columnMap);
+		if (list == null) {
+			return null;
+		}
+		return convertor.apply(list);
+	}
+
+	K getVoOne(Wrapper<T> queryWrapper, CopyOptions copyOptions);
+
+	default K getVoOne(Wrapper<T> queryWrapper) {
+		return getVoOne(queryWrapper, new CopyOptions());
+	}
+
+	default K getVoOne(Wrapper<T> queryWrapper, Function<T, K> convertor) {
+		return convertor.apply(getOne(queryWrapper, true));
+	}
+
+	List<K> listVo(Wrapper<T> queryWrapper, CopyOptions copyOptions);
+
+	default List<K> listVo(Wrapper<T> queryWrapper) {
+		return listVo(queryWrapper, new CopyOptions());
+	}
+
+	default List<K> listVo(Wrapper<T> queryWrapper, Function<Collection<T>, List<K>> convertor) {
+		List<T> list = getBaseMapper().selectList(queryWrapper);
+		if (list == null) {
+			return null;
+		}
+		return convertor.apply(list);
+	}
+
+	default List<K> listVo() {
+		return listVo(Wrappers.emptyWrapper());
+	}
+
+	default List<K> listVo(Function<Collection<T>, List<K>> convertor) {
+		return listVo(Wrappers.emptyWrapper(), convertor);
+	}
+
+	PagePlus<T, K> pageVo(PagePlus<T, K> page, Wrapper<T> queryWrapper, CopyOptions copyOptions);
+
+	default PagePlus<T, K> pageVo(PagePlus<T, K> page, Wrapper<T> queryWrapper) {
+		return pageVo(page, queryWrapper, new CopyOptions());
+	}
+
+	default PagePlus<T, K> pageVo(PagePlus<T, K> page, Wrapper<T> queryWrapper,
+								  Function<Collection<T>, List<K>> convertor) {
+		PagePlus<T, K> result = getBaseMapper().selectPage(page, queryWrapper);
+		return result.setRecordsVo(convertor.apply(result.getRecords()));
+	}
+
+	default PagePlus<T, K> pageVo(PagePlus<T, K> page) {
+		return pageVo(page, Wrappers.emptyWrapper());
+	}
+
+	default PagePlus<T, K> pageVo(PagePlus<T, K> page, Function<Collection<T>, List<K>> convertor) {
+		return pageVo(page, Wrappers.emptyWrapper(), convertor);
 	}
 
 	boolean saveAll(Collection<T> entityList);

--
Gitblit v1.9.3