這是我在DAOImpl(休眠)代碼:休眠錯誤時提交會議
@Transactional
public void insert(Cage cage) {
Session session = null;
Transaction tx = null;
try{
session = getHibernateTemplate().getSessionFactory().openSession();
tx = session.beginTransaction();
session.saveOrUpdate(cage);
session.flush();
session.clear();
tx.commit();
}catch(RuntimeException e){
try{
tx.rollback();
}catch(RuntimeException rbe){
rbe.printStackTrace();
System.out.println("Couldn’t roll back transaction");
}
throw e;
}finally{
if(session!=null){
session.close();
}
}
}
當第二次操作的數據錄入(同PK)發生這個問題:
org.hibernate.exception.ConstraintViolationException:無法執行JDBC批量更新
您應該包含整個堆棧跟蹤,而不是第一行。 – azurefrog
主鍵應該對每個條目都是唯一的,與第二個條目相同的pk肯定會給出該例外。 – kirti