我已经基于类的配置所以回滚transaction.I已经使用jdbcTemplate.My bean声明如下:
@Bean
public DriverManagerDataSource dataSource() {
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName("oracle.jdbc.driver.OracleDriver");
dataSource.setUrl("jdbc:oracle:thin:@192.168.1.5:1521:DCGCDB");
dataSource.setUsername("PCA_OWNER");
dataSource.setPassword("PCA_OWNER");
return dataSource;
}
<!--for transaction bean-->
@Bean
public PlatformTransactionManager txManager() {
return new DataSourceTransactionManager(dataSource());
}
所以在我的服务类我已经宣布了@Transactional,但它不工作:
@Service
public class ProcessAnexOneServiceImpl implements ProcessAnexOneService {
@Autowired
private SelectionCustomOfficeService selectionCustomOfficeService;
@Autowired
private LetterDocService letterDocService;
@Autowired
private LetterService letterService;
@Override
@Transactional
public void insertProcessAnexOne(ProcessAnexOne processAnexOne, String entryBy) {
BigDecimal zeroValue = new BigDecimal(0);
Letter letter = new Letter(processAnexOne.getLetter().getLetterId(), processAnexOne.getLetter().getInout(),
processAnexOne.getLetter().getInoutNo());
letter.setEntryBy(entryBy);
//1st insert Transaction happens here
BigDecimal letterNo = letterService.insertLetter(letter);
//1st insert Transaction ends here
System.out.println("letterNo from db is" + letterNo);
//2nd insert Transaction happens here
for (BigDecimal docId: processAnexOne.getDocId()) {
LetterDoc letterDoc = new LetterDoc(letterNo, singledocId, null, null);
letterDocService.insertLetterDoc(letterDoc, entryBy);
}
//2nd insert Transaction ends here
//3rd insert Transaction happens here
for (LetterDocOther letterDoc: processAnexOne.getLetterDocOthers()) {
System.out.println("entered hereasfdsafsdsdfg");
LetterDoc letterD = new LetterDoc(letterNo, letterDoc.getDocId(), null, "I",
letterDoc.getOthersDescription());
letterD.setEntryBy(entryBy);
letterDocService.insertLetterDocWithDescription(letterD);
}
//3rd insert Transaction ends here
}
}
我有三笔交易,这将创下三个不同的表在此服务class.So我的问题是,当第一次交易完成并且在第二次交易的错误,那么就没有任何回滚发生在1日transaction.At这一条件我还是第一次看到交易的数据在我的表,但错误是在第二次交易的到来。我宣布@Transaction标注为回滚,也试过(rollbackOn = Exception.class),但如果有错误时不rollbacking第一笔交易。
在我的pom.xml我已经加入:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>4.3.7.RELEASE</version>
</dependency>
letter service imp了.Java
@Service
public class LetterServiceImpl implements LetterService {
@Autowired
private LetterDao letterDao;
@Override
@Transactional(rollbackOn=Exception.class)
public BigDecimal insertLetter(Letter letter) {
BigDecimal letter1=letterDao.saveLetter(letter);
return letter1;
}
}
letter DAO imp了.Java
@Override
public BigDecimal saveLetter(Letter letter) {
try {
System.out.println("hitted123 here");
SimpleJdbcCall simpleJdbcCall = new SimpleJdbcCall(jdbcTemplate).withProcedureName("PCPR_ADD_LETTER");
Map<String, Object> inParamMap = new HashMap<String, Object>();
System.out.println(letter.getLetterId());
inParamMap.put("P_LETTER_NO",null);
inParamMap.put("P_LETTER_ID",letter.getLetterId());
inParamMap.put("P_SIGNATARY",letter.getSignatary());
inParamMap.put("P_LETTER_BOX",letter.getLetterBox());
inParamMap.put("P_ENTRY_BY",letter.getEntryBy());
inParamMap.put("P_R_STATUS","I");
inParamMap.put("P_REMINDER_YES_NO","N");
System.out.println("hitted1234 here");
SqlParameterSource in = new MapSqlParameterSource(inParamMap);
System.out.println("hitted123456789 here");
//Map<String, Object> out = simpleJdbcCall.execute(in);
BigDecimal letterNO = (BigDecimal) simpleJdbcCall.execute(in).get("P_LETTER_NO");
System.out.println("hitted12345 here"+letterNO);
return letterNO;
} catch(Exception e) {
e.printStackTrace();
}
return null;
}
据Spring Doc,ROLLBACK对于未处理的异常自动完成。在这种情况下,你要处理它,事务管理器将不会看到有一个错误。
在另一方面,回滚将与任何未经检查的异常的(那些延伸的RuntimeException)withouth的必要宣布他们在@Transactional注释发生。然而,检查注释(你需要在catch块来处理的)需要在@Transactional注释进行申报。
最后,我建议你添加的回滚最高水平的方法,也就是开始transacction的一个,以保证交易的行为。
问题是在LetterDaoImpl.java,你正赶上在方法saveLetter任何异常。如果您捕获异常,你不扔回去,你没有得到回滚。
此外,你应该检查注释@Transactional因为我敢肯定的语法是的rollbackFor()而不是rollbackOn()。
为了调试与交易,我通常启用日志在对org.springframework.jdbc.datasource.DataSourceTransactionManager调试级别。