今天事务搞了快一天,终于基本上搞定了,稍微总结下:
我使用的是S2SH 开发,所以,事务基本上是Spring来控制
配置事务:
首先在app-context.xml 文件中事务已经配好了,并在point参数中,你在service中写的方法已经配置好了
对于一般的情况,如果在一次事务中,对同一张表的操作只有一次,只需把dao的方法都放在service实现方法中就OK了
由于我做的项目比较大,不但配置了hibernate事务,并且还配置了jdbcTransactionInterceptor事务。所以,在事务中的写法有2种选择
由于业务的需要,在一个事务中,需要对同一张表进行多次操作,也就是在一个事物中,对同一张表不但有插入操作,并且还有更新操作或者是删除操作。
所以出现了一个这样的情况,第一次插入操作,很快,第二次进行更新操作就很慢了,最后导致表被锁,且时间过长,最后报如下的错: Lock wait timeout exceeded; try restarting transaction; nested exception is java.sql.SQLException: Lock wait timeout exceeded; try restarting transaction
当然,由于我本身是对于插入操作是用了hibernate的事务,而更新操作是用了jdbc的事务,所以就出现如上的错误
改正的办法是:
虽然改正的办法有很多,但在寻找的过程中还是蛮艰苦的!~
呵呵!~