我有一个简单的问题。我必须编写一个面向Tasklet的Spring Batch项目,该项目必须从DB中检索一些数据,流程信息。并将其写入.json文件。我正在使用Spring Data JPA,但这是这样做的正确和最安全的方法吗? 如果没有,那么编写此代码的最佳方法是什么? 非常感谢您的帮助!
最新的Tasklet阅读器代码:
public class DataReader implements Tasklet, StepExecutionListener {
@Autowired
EntityRepository entityRepository;
@Autowired
ProductRepository productRepository;
@Autowired
SuscriptionRepository suscriptionRepository;
@Autowired
MapperUtils mapperUtils;
private List<EntityDTO> entityDataDTO;
@Override
public RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext) throws Exception {
this.entityDataDTO = new ArrayList<EntityDTO>();
List<Entidad> entities = entityRepository.findAll();
for (Entidad entity : entities) {
List<SuscriptionDTO> suscriptionsDTO = new ArrayList<SuscriptionDTO>();
for (Suscripcion suscription : entity.getSuscripciones()) {
List<Suscripcion> suscriptionsByProduct = suscriptionRepository.findSuscriptionsByEntityIdAndSuscriptionId(suscription.getId().getIdEntidadEurbt(), suscription.getId().getIdSuscripcion());
List<String> suscriptionProducts = new ArrayList<String>();
for (Suscripcion suscriptionProduct : suscriptionsByProduct) {
Producto product = productRepository.findById(suscriptionProduct.getId().getIdProductoEurbt()).get();
suscriptionProducts.add(product.getTlDescProducto());
}
SuscriptionDTO suscriptionDTO = mapperUtils.mapSuscriptionDataToSuscriptionDTO(suscription, suscriptionProducts);
if (!suscriptionsDTO.contains(suscriptionDTO))
suscriptionsDTO.add(suscriptionDTO);
}
this.entityDataDTO.add(mapperUtils.mapEntityDataToEntityDTO(entity, suscriptionsDTO));
}
return RepeatStatus.FINISHED;
}
@Override
public void beforeStep(StepExecution stepExecution) {
}
@Override
public ExitStatus afterStep(StepExecution stepExecution) {
stepExecution.getJobExecution().getExecutionContext().put("entityDataDTO", this.entityDataDTO);
return ExitStatus.COMPLETED;
}
}
答案 0 :(得分:1)
使用Tasklet
读取,处理和写入整个数据集并不是最佳方法,因为整个数据集只有一个事务。 chunk-oriented step更适合您的用例。通过面向块的处理,每个块将只有一个事务。
希望这会有所帮助。