项目使用ssm,因为要写一个售票系统,我在售票接口里面写了一个线程方法保证线程安全问题,然后在线程里面使用事务回滚保证数据不会因为系统错误导致数据添加错误,但是事务回滚却出现了一个很奇怪的问题。
这是我线程里面事务回滚的写法:
@Override
public void run(){
if(this.sd_id!=null){
this.stock = schedulingDao.findStock(this.sd_id);
}
if(this.stock>0){
synchronized (obj){
DefaultTransactionDefinition def = new DefaultTransactionDefinition();
def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED );
PlatformTransactionManager txManager = SpringUtil.getBean(PlatformTransactionManager.class);
TransactionStatus status = txManager.getTransaction(def);
try{
TicketInspectRecord ticketInspectRecord = new TicketInspectRecord();
ticketInspectRecord.setTir_tcr_id(1);
ticketInspectRecord.setTir_tp_id(1);
ticketInspectRecord.setTir_u_id(1);
ticketInspectRecord.setTir_date(new Date());
ticketInspectRecordDao.insert(ticketInspectRecord);
schedulingDao.updateStock(this.sd_id);//这一句必报错误,所以必定进入txManager.rollback(status)
}catch(Exception e){
e.printStackTrace();
txManager.rollback(status);
}
}
}
}
因为我的代码里面有两个修改数据库的方法:ticketInspectRecordDao.insert(ticketInspectRecord)和 schedulingDao.updateStock(this.sdid),我的想法是第二个updateStock方法出错时,回滚insert方法。
但是很奇怪的一点:经常会出现,项目重新启动之后,或者隔一段时间再运行一次这方法时,即便进入回滚方法,insert方法还是会执行。但是再运行,insert方法就正常回滚了。
排除很多遍都不知道问题出在哪里。。。。