org.hibernate.LazyInitializationException: не удалось инициализировать прокси - нет сеанса. Spring + Hibernate + HSQLDB

1

У меня есть некоторые проблемы с конфигурацией Spring + Hibernate + HSQLDB. Я получаю:

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.hibernate.LazyInitializationException: could not initialize proxy - no Session
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:894)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
root cause

org.hibernate.LazyInitializationException: could not initialize proxy - no Session
org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:167)
org.hibernate.proxy.AbstractLazyInitializer.getImplementation(AbstractLazyInitializer.java:215)
org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:190)
org.siwoz.dao.model.Person_$$_javassist_0.toString(Person_$$_javassist_0.java)
org.siwoz.controller.IndexController.index(IndexController.java:31)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:483)
org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:212)
org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:126)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:96)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:617)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:578)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:900)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:827)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)

Я попытался использовать OpenSessionInViewInterceptor (для hibernate 3), но затем у меня есть:

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.IllegalArgumentException: Resource must not be null
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:894)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
root cause

java.lang.IllegalArgumentException: Resource must not be null
org.springframework.util.Assert.notNull(Assert.java:112)
org.springframework.transaction.support.TransactionSynchronizationUtils.unwrapResourceIfNecessary(TransactionSynchronizationUtils.java:62)
org.springframework.transaction.support.TransactionSynchronizationManager.hasResource(TransactionSynchronizationManager.java:124)
org.springframework.orm.hibernate3.support.OpenSessionInViewInterceptor.preHandle(OpenSessionInViewInterceptor.java:143)
org.springframework.web.servlet.handler.WebRequestHandlerInterceptorAdapter.preHandle(WebRequestHandlerInterceptorAdapter.java:54)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:891)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:827)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)

Вот мой файл cfg:

@Configuration
@EnableTransactionManagement
@PropertySource({ "classpath:db/db.properties" })
@ComponentScan({ "my_package_name" })
public class PersistenceConfig {

@Autowired
Environment env;

@Bean
public AnnotationSessionFactoryBean sessionFactory() {
    AnnotationSessionFactoryBean sessionFactory = new AnnotationSessionFactoryBean();
    sessionFactory.setDataSource(restDataSource());
    sessionFactory
            .setPackagesToScan(new String[] { "my_package_name" });
    sessionFactory.setHibernateProperties(hibernateProperties());
    try {
        sessionFactory.afterPropertiesSet();
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    return sessionFactory;
}

@Bean
public HibernateTemplate hibernateTemplate() {
    return new HibernateTemplate(sessionFactory().getObject());
}

@Bean
public DataSource restDataSource() {
    BasicDataSource dataSource = new BasicDataSource();
    dataSource.setDriverClassName(env.getProperty("jdbc.driverClassName"));
    dataSource.setUrl(env.getProperty("jdbc.url"));
    dataSource.setUsername(env.getProperty("jdbc.user"));
    return dataSource;
}

@Bean
public HibernateTransactionManager transactionManager() {
    HibernateTransactionManager txManager = new HibernateTransactionManager();
    txManager.setSessionFactory(sessionFactory().getObject());
    return txManager;
}

@Bean
public HibernateExceptionTranslator hibernateExceptionTranslator() {
    return new HibernateExceptionTranslator();
}

Properties hibernateProperties() {
    return new Properties() {
        private static final long serialVersionUID = 8249579451140862991L;
        {
            setProperty("hibernate.connection.pool_size",
                    env.getProperty("hibernate.conn.pool"));
            setProperty("hibernate.hbm2ddl.auto",
                    env.getProperty("hibernate.hbm2ddl.auto"));
            setProperty("hibernate.dialect",
                    env.getProperty("hibernate.dialect"));
            setProperty("hibernate.globally_quoted_identifiers", "true");
            setProperty(
                    "hibernate.globally_quoted_identifiers",
                    env.getProperty("hibernate.cache.use_second_level_cache"));
            setProperty("hibernate.globally_quoted_identifiers",
                    env.getProperty("hibernate.cache.use_query_cache"));
        }
    };
}
}

У меня есть абстрактный репозиторий, вот фрагмент кода:

public abstract class AbstractRepository<T> {

@Autowired
protected HibernateTemplate hibernateTemplate;

public abstract T getById(long id);
}

И вот мой PersonRepository:

@Repository("personRepository")
public class PersonRepository extends AbstractRepository<Person> {

@Override
     public Person getById(long id) {
    return hibernateTemplate.load(Person.class, id);
}

Я использую только конфигурацию аннотации (без xmls) и загружаю свою схему db и данные из файлов *.sql. Я могу видеть схему и данные в hsql-менеджере.
Исключения происходят, когда я вызываю getById(). Я также проверил свой объект в sessionFactory.getObject(). GetAllClassMetadata() - его загрузили.

Весна - 3,1
Спящий режим - 3.6.10.
Tomcat - 7
HSQLDB - 2.3.2
Я думаю, что есть глупая ошибка, но я не вижу этого. Есть идеи? Большое спасибо!

РЕДАКТИРОВАТЬ:
Я заметил странные ошибки в консоли Tomcat:

[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:386) Unsucces
sful: create table 'Address' ('id' bigint not null auto_increment, 'city' varcha
r(255), 'street' varchar(255), primary key ('id'))
[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:387) unexpect
ed token:  required: (
[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:386) Unsucces
sful: create table 'Person' ('id' bigint not null auto_increment, 'name' varchar
(255), 'pass' varchar(255), 'pesel' varchar(255), 'surname' varchar(255), primar
y key ('id'))
[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:387) unexpect
ed token:  required: (
[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:386) Unsucces
sful: create table 'Address' ('id' bigint not null auto_increment, 'city' varcha
r(255), 'street' varchar(255), primary key ('id'))
[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:387) unexpect
ed token:  required: (
[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:386) Unsucces
sful: create table 'Person' ('id' bigint not null auto_increment, 'name' varchar
(255), 'pass' varchar(255), 'pesel' varchar(255), 'surname' varchar(255), primar
y key ('id'))
[ERROR] [localhost-startStop-1 06:06:19] (SchemaExport.java:create:387) unexpect
ed token:  required: (

Я не знаю, где ошибка может быть, я также добавляю часть db_scheme:

CREATE TABLE Address (
id INTEGER GENERATED BY DEFAULT AS IDENTITY primary key,
city varchar(64),
street varchar(64)
);

В hsqldb gui ошибок нет, когда я удаляю/добавляю схему и данные.

  • 0
    Попробуйте get вместо load , последний всегда создает прокси, а не идти в базу данных. Он попадет в базу данных только тогда, когда вы захотите получить доступ к свойствам фактической базовой записи. Также вам больше не следует использовать HibernateTemplate , а просто SessionFactory , используйте sessionFactory.getCurrentSession для получения доступа к базовому сеансу. (Это также скажет, когда у вас нет правильной настройки транзакции).
  • 0
    Да, я читал о HibernateTemplate, я просто хотел попробовать все возможные решения :) Хорошо, я сделал то, что вы сказали: Session session = sessionFactory.getCurrentSession (); return (Person) session.get (Person.class, 1L); и имеют следующие исключения: pastebin.com/sFZiygEp
Показать ещё 1 комментарий
Теги:
spring
spring-mvc
hibernate
jpa

2 ответа

0

Спасибо всем за ответы.
К сожалению, я не нашел решения для своей проблемы.
Я создал самый простой объект с единственным id, и проблема была такой же.
Я использовал другую базу данных - MySQL - и теперь все в порядке.

  • 0
    Вы можете опубликовать свои сопоставления, свои модели и конфигурацию гибернации?
0

Вы должны использовать аннотацию @Transactional

Попробуйте что-то вроде этого:

@Repository("personRepository")
@Transactional
public class PersonRepository extends AbstractRepository<Person> {

@Override
     public Person getById(long id) {
    return hibernateTemplate.load(Person.class, id);
}

Надеюсь, это поможет Анджело

  • 0
    Извините, я не упоминал об этом раньше - я использую @Transactional на уровне сервиса. Моя цепочка запросов выглядит так: JSP (пользователь заходит на страницу) - Контроллер - PersonService - PersonRepository. В любом случае спасибо за быстрый ответ (я все равно попробовал, но результат был тот же).

Ещё вопросы

Сообщество Overcoder
Наверх
Меню