在生产中经常会遇到大批量数据操作,如果直接大批量的数据对数据直接操作,则可能造成数据库执行时间过长,造成数据库压力过大。这里采用大批量数据分割成一块块小的数据,再对数据操作的方式来解决这种问题,也是我们常见的一种方式。虽然比较简单,但是网上给出的解决方案,不尽如人意。下面上我的代码
import java.util.ArrayList;
import java.util.List;
/**
* 大list拆分为多个小list处理
* @param <T>
*/
public class ListSplitUtil<T extends Object> {
/**
*
* @param list 要拆分的list
* @param size 每次拆分的大小
* @param <T>
* @return
*/
public static<T> List<List<T>> split(List<T> list, int size){
if(list==null || list.size()==0){
return null;
}
// 获得数据总量
int count = list.size();
// 计算出要分成几个批次
int pageCount = (count / size) + (count % size == 0 ? 0 : 1);
List<List<T>> temp = new ArrayList<>(pageCount);
for (int i = 0, from = 0,to = 0; i < pageCount; i&#