gpt4 book ai didi

java - hibernate中的 session 和 session 工厂

转载 作者:行者123 更新时间:2023-12-01 12:00:06 24 4
gpt4 key购买 nike

我正在使用 Java、Hibernate 和 SQL Server 创建一个应用程序。我对 Session 和 Session Factory 的对象声明有疑问。起初,当我开始创建应用程序时,我经常在需要时创建 session 和 session 工厂。但现在我注意到,当我如上所述创建 session 和 session 工厂时,我的应用程序变得很慢,因此我开始在登录页面创建所有需要的 session 和 session 工厂,并将修饰符指定为 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();

现在,每当我需要使用 session 和 session 工厂时,我都会将 session 称为 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();

首先我没有使用hibernate的回滚功能。但现在我想实现hibernate的回滚功能。因此,采用哪种方法会给我带来更好的性能。请给我建议一个方法。提前致谢。

最佳答案

最重要的事情:永远不要为每个应用程序创建多个 SessionFactory(除非您有多个持久性上下文,然后为每个应用程序和持久性上下文创建一个)。继续创建 SessionFactories 会首先降低你的性能,然后由于 OutOfMemoryError 导致你的应用服务器。在应用程序启动时创建一个 SessionFactory 并将其保存在可访问的地方 - 将其存储在 jndi 中,将其保存在全局类或类似的类中。

根据需要创建Session - 最佳匹配通常是每个事务一个Session,因此hibernate可以利用其缓存机制。

关于java - hibernate中的 session 和 session 工厂,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28037603/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com