|
@@ -1,20 +1,21 @@
|
|
|
package com.ruoyi.common.core.mybatisplus.core;
|
|
|
|
|
|
import cn.hutool.core.bean.copier.CopyOptions;
|
|
|
-import com.baomidou.mybatisplus.annotation.TableId;
|
|
|
-import com.baomidou.mybatisplus.annotation.TableName;
|
|
|
+import cn.hutool.core.util.ObjectUtil;
|
|
|
import com.baomidou.mybatisplus.core.conditions.Wrapper;
|
|
|
+import com.baomidou.mybatisplus.core.metadata.TableInfo;
|
|
|
+import com.baomidou.mybatisplus.core.metadata.TableInfoHelper;
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.Assert;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.ClassUtils;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
import com.ruoyi.common.core.page.PagePlus;
|
|
|
import com.ruoyi.common.utils.BeanCopyUtils;
|
|
|
+import com.ruoyi.common.utils.reflect.ReflectUtils;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.core.ResolvableType;
|
|
|
|
|
|
import java.io.Serializable;
|
|
|
-import java.lang.annotation.Annotation;
|
|
|
-import java.lang.reflect.Field;
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.Collection;
|
|
|
import java.util.List;
|
|
@@ -119,31 +120,37 @@ public class ServicePlusImpl<M extends BaseMapperPlus<T>, T, K> extends ServiceI
|
|
|
|
|
|
/**
|
|
|
* 单sql批量插入( 全量填充 )
|
|
|
- * 适用于无脑插入
|
|
|
*/
|
|
|
@Override
|
|
|
public boolean saveAll(Collection<T> entityList) {
|
|
|
- ArrayList<T> list = new ArrayList<>();
|
|
|
- for (T t : entityList) {
|
|
|
- try {
|
|
|
- //获取属性注解的value值
|
|
|
- Field f = t.getClass().getDeclaredField("id");
|
|
|
- f.setAccessible( true );//设置可以范围private
|
|
|
- Object o = f.get(t);//获取出id的值
|
|
|
- System.out.println(o);
|
|
|
- if (o == null) {
|
|
|
- //如果id为null,插入
|
|
|
- list.add(t);
|
|
|
- } else {
|
|
|
- //否则更新
|
|
|
- baseMapper.updateById(t);
|
|
|
- }
|
|
|
-
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
+ return baseMapper.insertAll(entityList) == entityList.size();
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 全量保存或更新 ( 按主键区分 )
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public boolean saveOrUpdateAll(Collection<T> entityList) {
|
|
|
+ TableInfo tableInfo = TableInfoHelper.getTableInfo(entityClass);
|
|
|
+ Assert.notNull(tableInfo, "error: can not execute. because can not find cache of TableInfo for entity!");
|
|
|
+ String keyProperty = tableInfo.getKeyProperty();
|
|
|
+ Assert.notEmpty(keyProperty, "error: can not execute. because can not find column for id from entity!");
|
|
|
+ List<T> addList = new ArrayList<>();
|
|
|
+ List<T> updateList = new ArrayList<>();
|
|
|
+ int row = 0;
|
|
|
+ for (T entity : entityList) {
|
|
|
+ Object id = ReflectUtils.invokeGetter(entity, keyProperty);
|
|
|
+ if (ObjectUtil.isNull(id)) {
|
|
|
+ addList.add(entity);
|
|
|
+ } else {
|
|
|
+ updateList.add(entity);
|
|
|
}
|
|
|
}
|
|
|
- return baseMapper.insertAll(list) == list.size();
|
|
|
+ if (updateBatchById(updateList)) {
|
|
|
+ row += updateList.size();
|
|
|
+ }
|
|
|
+ row += baseMapper.insertAll(addList);
|
|
|
+ return row == entityList.size();
|
|
|
}
|
|
|
|
|
|
/**
|