FunctionalInterface~一個批量處理(li)數據的類
主要使用了一個(ge)委托的(de)方(fang)式 ,函數式接口,將需要處(chu)理的(de)業務邏輯以(yi)參(can)數的(de)方(fang)式傳到方(fang)法里,而(er)批(pi)量處(chu)理的(de)方(fang)法代碼比較固定,所以(yi)進行了抽象。
/**
* 數據處理輔助類.
*/
public class DataHelper {
static Logger logger = LoggerFactory.getLogger(DataHelper.class);
/**
* 分頁處理邏輯.
*
* @param total
* @param mapper
* @param query
* @param consumer
* @param <T>
*/
public static <T> void fillDataByPage(int total,
int pageSize,
BaseMapper<T> mapper,
QueryWrapper<T> query,
Consumer<T> consumer) {
Integer totalPage = total / pageSize;
if (totalPage > pageSize && totalPage % pageSize != 0) {
totalPage++;
}
for (int i = 1; i <= totalPage; i++) {
IPage<T> pages = mapper.selectPage(
new Page<>(i, pageSize), query);
List<T> list = pages.getRecords();
for (T item : list) {
consumer.accept(item);
}
logger.info("【當前數據頁:{}/{}】", i, pageSize);
}
}
}
業務層在使用批量大數據處理時,可以直接調用這個fillDataByPage方法,它們(men)只關注自(zi)己(ji)的業(ye)務(wu)邏輯即可。
QueryWrapper<UserAccountSet> actRuExecutionQueryWrapper = new QueryWrapper<>();
actRuExecutionQueryWrapper.eq("AccountState", 0);
Integer total = userAccountSetDao.selectCount(actRuExecutionQueryWrapper);
DataHelper.fillDataByPage(total, DATA_PAGE_SIZE, userAccountSetDao, actRuExecutionQueryWrapper, (userAccountSet) -> {
// 業務邏輯代碼
});