try {
//得到结账流水号
String accountBalanceID = SequenceService.getNewSequenceID("account_charge_no", dataSource); //TODO:改为业务主键生成方式
ChargeBalance charge = new ChargeBalance();
charge.setAccountDate(acctDate);
charge.setAccountNo(accountBalanceID);
charge.setOperator(operatorName);
charge.setMaxRcptNo(maxRcptNo);
charge.setMinRcptNo(minRcptNo);
charge.setFreeNum(0);
charge.setChargeNum(Integer.parseInt(chargeNum));
charge.setReturnNum(Integer.parseInt(returnNum));
charge.setChargeFee(Double.parseDouble(chargeFee));
charge.setChargeCost(Double.parseDouble(chargeCost));
charge.setReturnFee(Double.parseDouble(returnFee));
charge.setXNHCharge(Double.parseDouble(XNHCharge));
//收费结账结算
AccountBalanceOfChargeService service = new AccountBalanceOfChargeService(dataSource);
service.doChargeOfBalanceByTime(hospitalID, charge, startTime, endTime);
context.addDataField(Constants.JSON_RESULT_NAME, accountBalanceID);
} catch (Exception e) {
//设置为回滚状态
this.getTransaction().setRollbackOnly(true); log.error("DoAccountOfChargeAction is Error!",e);
}
请问如果 service里面的sql没有插入成功这种事务处理可以吗?

解决方案 »

  1.   

    要不你做添加的时候做下判断,添加成功TRUE,否则FALSE
    然后通过这个值来做事务的回滚操作
      

  2.   

    这种写法太陌生了,好久没用过了,所以不敢说对错。现在我都用spring框架里面的事务处理事务TransactionManager trans = new TransactionManager();// 框架自动回滚
    try {
    trans.start();
    AccountBalanceOfChargeService service = new AccountBalanceOfChargeService(dataSource);
    service.doChargeOfBalanceByTime(hospitalID, charge, startTime, endTime);
    context.addDataField(Constants.JSON_RESULT_NAME, accountBalanceID);
    trans.commit(); } finally {
    trans.end();
    }