我正在使用下面的方法来解决hibernate.Pleas中唯一的惰性初始化问题,告诉我它是否可以工作。由于某些原因,我不得不在我的持久层中实现我的事务处理。
public class CourseDAO {
Session session = null;
public CourseDAO()
{
this.session = this.session = HibernateUtil.getSessionFactory().getCurrentSession();
}
public Course findByID(int cid){
Course crc = null;
Transaction tx = null;
try {
tx = session.beginTransaction();
Query q = session.createQuery("from Course as course where course.cid = "+cid+" ");
crc = (Course) q.uniqueResult();
//note that i am not commiting my transcation here.Because If i do that i will not be able to
//do lazy fetch
}
catch (HibernateException e)
{
e.printStackTrace();
tx.rollback();
throw new DataAccessLayerException(e);
}
finally
{
}
return crc;
}
}在过滤器中,我使用了下面的代码
session = HibernateUtil.getSessionFactory().getCurrentSession();
if(session.isOpen())
HibernateUtil.getSessionFactory().getCurrentSession().getTransaction().commit();这种方法正确吗??它会有什么问题吗?
发布于 2009-07-28 15:32:08
你能解释一下为什么你需要在你的存储库中有你的事务吗?问题是它们将是非常细粒度的,所以您不会从会话缓存中获得任何优势
然后在那里打开事务,但在筛选器中关闭它。如果访问服务中的多个存储库,会发生什么情况?也许我没有理解您的意思,但我认为您需要重新思考迫使您在存储库中管理事务的原因
发布于 2009-11-10 22:06:45
你什么时候创建你的CourseDAO?如果它是单例bean或其他比页面视图存在时间更长的东西,它将需要保留一个SessionFactory并在需要时生成一个新会话,而不是保留一个会话。
https://stackoverflow.com/questions/782272
复制相似问题