为什么我的服务在从组件调用时不写入数据库?

why my services doen't write in database when calling them from components?

我正在为 Camunda 流程创建委托表达式,工作流运行完美,但是当它执行委托时,我的服务创建了对象,但没有将它们写入数据库。 这是代码:

@Component
public class CreateNewROAction implements JavaDelegate {

    private final ROactionService rOactionService;
    private final RiskService riskService;
    private Logger logger = LoggerFactory.getLogger(CreateNewROAction.class);
    public CreateNewROAction(ROactionService rOactionService, RiskService riskService) {
    this.rOactionService = rOactionService;
    this.riskService = riskService;
}

    @Override
    public void execute(DelegateExecution delegateExecution) throws Exception {

        String processInstanceId = delegateExecution.getProcessInstanceId();
        String riskId = delegateExecution.getVariable("riskId").toString();
        Risk risk = riskService.findById(Long.parseLong(riskId));
        ROaction rOaction = new ROaction();
        rOaction.setProcessInstanceId(processInstanceId);
        rOaction = rOactionService.save(rOaction);
        logger.info("roAction object: " + rOaction.toString());
        risk.setAction(rOaction);
        risk = riskService.update(risk, risk.getId());
        logger.info("risk object: " + risk.toString());
        delegateExecution.setVariable("id", rOaction.getId());

    }
}

记录器显示了我预期的结果:

roAction object: ROaction(id=4, description=null, status=null, responsible=null, deadline=null, AchievementDate=null, effectivenessEvaluationDate=null, effectivenessEvaluation=null, processInstanceId=819, createdAt=Wed Jul 03 15:08:19 CET 2019, updatedAt=Wed Jul 03 15:08:19 CET 2019)
risk object: Risk(id=4, description=null, probability=0, impact=0, cause=null, consequence=null, createdAt=2019-07-03 15:07:04.975, updatedAt=2019-07-03 15:07:04.975, processes=[], action=ROaction(id=4, description=null, status=null, responsible=null, deadline=null, AchievementDate=null, effectivenessEvaluationDate=null, effectivenessEvaluation=null, processInstanceId=819, createdAt=Wed Jul 03 15:08:19 CET 2019, updatedAt=Wed Jul 03 15:08:19 CET 2019), processInstanceId=801)

但是数据库是空的。
备注:
1. 我必须将实体的 ID 更改为 @GeneratedValue(strategy = GenerationType.SEQUENCE) 因为在此之前服务 returns 来自 save() 函数的空 ID
2.控制器的服务工作正常

解决方法是不直接调用服务方法,而是通过@Transactional注解的私有方法调用。原因是 Hibernate 在第一次调用时打开与数据库的连接,然后关闭它。该组件与数据库只有一个连接,因此在第一次调用后无法访问它。 @Transactional 为该方法打开一个与数据库的新连接。