[英]Session and session factory in hibernate
我正在使用Java,Hibernate和SQL Server创建应用程序。 我对Session和Session Factory对象的声明有疑问。 首先,当我开始创建应用程序时,我经常在需要时创建会话和会话工厂。 但是现在我注意到,当我如上所述创建会话和会话工厂时,我的应用程序变慢,因此我开始在“登录”页面上创建所有需要的会话和会话工厂,并将修饰符指定为public static。
public static Session session = null;
public static SessionFactory sessionfactory = new org.hibernate.cfg.Configuration().configure().buildSessionFactory();
public static Session session1 = null;
public static SessionFactory sessionfactory1 = new org.hibernate.cfg.Configuration().configure().buildSessionFactory();
public static Session session2 = null;
public static SessionFactory sessionfactory2 = new org.hibernate.cfg.Configuration().configure().buildSessionFactory();
现在,每当需要使用会话和会话工厂时,我都习惯将这些会话称为Login.session(loginpagefilename.sessionobject)。
Login.session = Login.sessionfactory.openSession();
Login.session.beginTransaction();
String hql = "FROM TEST_SERVICES_POJO lts WHERE NOT EXISTS (SELECT lsm.inttestid FROM PARAMETER_MAPPING_POJO lsm WHERE lsm.status = 1 and lsm.inttestid=lts.inttestid)";
org.hibernate.Query query = Login.session.createQuery(hql);
DefaultTableModel model = (DefaultTableModel) testtable.getModel();
model.setRowCount(0);
for (Iterator it = query.iterate(); it.hasNext();) {
TEST_SERVICES_POJO slp = (TEST_SERVICES_POJO) it.next();
Object[] row = {slp.getTestname()};
model.addRow(row);
}
Login.session.getTransaction().commit();
首先,我没有使用休眠的回滚功能。 但是现在我希望实现休眠的回滚功能。 因此,遵循以下方法将为我带来更好的性能。 请给我一种方法。 提前致谢。
最重要的事情:每个应用程序永远不要创建多个SessionFactory
(除非您拥有多个持久化上下文,然后再为每个应用程序和持久性上下文创建一个)。 继续创建SessionFactories
将首先导致性能SessionFactories
,然后由于OutOfMemoryError
应用服务器。 在应用程序启动时创建一个SessionFactory
,并将其保留在可访问的位置-将其存储在jndi中,将其保留在全局类中。
根据需要创建Session
最佳匹配通常是每个事务一个Session
,因此休眠可以利用其缓存机制。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.