весенняя загрузка и спящий режим 5 - управление сессиями EntityManagerFactory - PullRequest
0 голосов
/ 12 ноября 2018

Я работаю над своим первым веб-приложением с Spring-boot и hibernate.

Я написал свой первый DAO следующим образом:

package myapplication.orderinfo;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import javax.persistence.EntityManagerFactory;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;

@Component
public class OrderInfoDaoImpl implements OrderInfoDao {

    @Autowired
    private EntityManagerFactory entityManagerFactory;

    public List<OrderInfo> getOrderInfoDetails() {
        Session session = entityManagerFactory.unwrap(SessionFactory.class).openSession();
        CriteriaBuilder builder = session.getCriteriaBuilder();
        CriteriaQuery criteria = builder.createQuery(OrderInfo.class);
        Root contactRoot = criteria.from(OrderInfo.class);
        criteria.select(contactRoot);
        return session.createQuery(criteria).getResultList();

    }

    public List<OrderInfo> getOrderInfo(String typeName) {
        Session session = entityManagerFactory.unwrap(SessionFactory.class).openSession();
        CriteriaBuilder builder = session.getCriteriaBuilder();
        CriteriaQuery criteria = builder.createQuery(OrderInfo.class);
        Root contactRoot = criteria.from(OrderInfo.class);
        criteria.where(builder.equal(contactRoot.get("typeName"), typeName));
        return session.createQuery(criteria).getResultList();

    }
}

Правильно ли вызыватьentityManagerFactory в каждом методе, как это?Я прочитал несколько статей по этому вопросу, я понял, что сеанс закрывается инструментом в конце каждого запроса, это правильно?

Все выглядит хорошо при запуске, но после нескольких запросов в приложенииУ меня такой сбой:

Hibernate: select distinct orderinfo0_.projectLeader as col_0_0_ from t_orderInfo orderinfo0_
2018-11-12 15:12:11.746  WARN 11360 --- [nio-8080-exec-7] o.h.engine.jdbc.spi.SqlExceptionHelper   : SQL Error: 0, SQLState: null
2018-11-12 15:12:11.747 ERROR 11360 --- [nio-8080-exec-7] o.h.engine.jdbc.spi.SqlExceptionHelper   : HikariPool-1 - Connection is not available, request timed out after 30000ms.
2018-11-12 15:12:11.752 ERROR 11360 --- [nio-8080-exec-7] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is javax.persistence.PersistenceException: org.hibernate.exception.JDBCConnectionException: Unable to acquire JDBC Connection] with root cause

java.sql.SQLTransientConnectionException: HikariPool-1 - Connection is not available, request timed out after 30000ms.
        at com.zaxxer.hikari.pool.HikariPool.createTimeoutException(HikariPool.java:669) ~[HikariCP-2.7.9.jar:na]

Мне интересно, если это произойдет из-за моей реализации / использования сеанса Hibernate.

Любая помощь будет благодарна: о) Спасибо

1 Ответ

0 голосов
/ 12 ноября 2018

Причина в том, что вы не закрываете сеанс. Также лучше правильно работать с транзакциями.

Этот подход можно проверить, если вы хотите работать с сеансом и трансациями вручную https://stackoverflow.com/a/36278975/3405171

Возможно, вам потребуется прочитать аннотацию Spring @Transactional и данные Spring, если вы еще этого не сделали.

...