如果我不在 limsservice 的审计方法上放置 @Transactional 注释,审计日志不会持久化。但是持久化服务中的持久化方法已经有了这个注释。为什么我必须放置这个注释。
@RequestMapping(value = "/lemf", method = RequestMethod.POST, headers = "Accept=application/json")
public
@ResponseBody
Lemf create(HttpServletResponse response, @RequestBody Lemf lemf) {
try {
Lemf l = limsService.findLemfByName(lemf.getName());
if (l == null) {
lemf= limsService.addLemf(lemf);
limsService.audit("User action",getRequestInfo(),"New lemf created.");
return lemf;
}
sendError(response, "Lemf Allready exist.");
} catch (ProviderException e) {
sendError(response, e);
}
return null;
}
public class PersistenceServiceImpl implements PersistenceService {
@Transactional(readOnly = false)
public <T extends Persistable> T persist(T obj) {
if (obj.getSystemId() != AbstractPersistable.UNSAVED_ID_VALUE) {
log.info("Updating... :" + obj);
T merged = em.merge(obj);
return merged;
} else {
em.persist(obj);
return obj;
}
}
}
public class LimsServiceImpl implements LimsService {
@Override
public Lemf addLemf(Lemf lemf) throws ProviderException {
return persistenceService.persist(lemf);
}
@Transactional
public void audit(String type,Pair<String,String > pair,String log) {
auditService. audit("User action", pair, "New lemf created.");
}
}