简体   繁体   English

org.hibernate.LazyInitializationException:无法初始化代理-没有会话。 Spring + Hibernate + HSQLDB

[英]org.hibernate.LazyInitializationException: could not initialize proxy - no Session. Spring + Hibernate + HSQLDB

I have some problems with Spring + Hibernate + HSQLDB configuration. 我在Spring + Hibernate + HSQLDB配置方面遇到一些问题。 I receive: 我收到:

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)

I've tried to use OpenSessionInViewInterceptor (for hibernate 3), but then i have: 我试图使用OpenSessionInViewInterceptor(用于休眠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)

Here is my cfg file: 这是我的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"));
        }
    };
}
}

I have an abstract repository, here is the piece of code: 我有一个抽象存储库,这是一段代码:

public abstract class AbstractRepository<T> {

@Autowired
protected HibernateTemplate hibernateTemplate;

public abstract T getById(long id);
}

And here is my PersonRepository: 这是我的PersonRepository:

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

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

I'm using only annotation config (no xmls) and loading my db scheme and data from *.sql files - I can see the scheme and data in hsql manager. 我仅使用批注配置(无xmls),并从* .sql文件加载我的数据库方案和数据-我可以在hsql管理器中看到该方案和数据。
Exceptions occur when I invoke getById(). 当我调用getById()时发生异常。 I also checked my entity in sessionFactory.getObject().getAllClassMetadata()- its loaded. 我还在sessionFactory.getObject()。getAllClassMetadata()中检查了我的实体-已加载它。

Spring - 3.1 春季-3.1
Hibernate - 3.6.10.Final 休眠-3.6.10.Final
Tomcat - 7 雄猫-7
HSQLDB - 2.3.2 HSQLDB-2.3.2
I think there is a stupid mistake, but I cannot see it. 我认为这是一个愚蠢的错误,但我看不到它。 Any ideas? 有任何想法吗? Thanks a lot! 非常感谢!

EDIT: 编辑:
I noticed strange errors in my Tomcat console: 我在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: (

I don't know where the error could be, I'm also adding piece of db_scheme: 我不知道错误可能在哪里,我还在添加db_scheme:

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

In hsqldb gui there are no errors, when I'm deleting/adding scheme and data. 在hsqldb gui中,删除/添加方案和数据时没有错误。

You need to use the @Transactional annotation 您需要使用@Transactional批注

Try something like this: 尝试这样的事情:

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

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

I hope this can help Angelo 我希望这可以帮助安吉洛

Thank you all for the answers. 谢谢大家的回答。
Unfortunately I haven't find any solution to my problem. 不幸的是,我没有找到解决问题的办法。
I created most simple entity with only id, and problem was the same. 我创建了只有ID的最简单的实体,问题也一样。
I used different database - MySQL - and everything is fine now. 我使用了不同的数据库-MySQL-现在一切都很好。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 Spring JPA - org.hibernate.LazyInitializationException:无法初始化代理 - 无 Z71AB3B3AE294B3ABDE46 - Spring JPA - org.hibernate.LazyInitializationException: could not initialize proxy - no Session 休眠问题:org.hibernate.LazyInitializationException:无法初始化代理-没有会话 - Hibernate issue: org.hibernate.LazyInitializationException: could not initialize proxy - no Session (org.hibernate.LazyInitializationException)org.hibernate.LazyInitializationException:无法初始化代理-没有会话 - (org.hibernate.LazyInitializationException) org.hibernate.LazyInitializationException: could not initialize proxy - no Session org.hibernate.LazyInitializationException:无法初始化代理-没有会话-很少发生 - org.hibernate.LazyInitializationException: could not initialize proxy - no Session - occurs rarely 如何修复 org.hibernate.LazyInitializationException - 无法初始化代理 - 没有 Session - How to fix org.hibernate.LazyInitializationException - could not initialize proxy - no Session JPA存储库org.hibernate.LazyInitializationException:无法初始化代理-没有会话 - JPA repository org.hibernate.LazyInitializationException: could not initialize proxy - no Session org.hibernate.LazyInitializationException:无法初始化代理 - 没有会话? - org.hibernate.LazyInitializationException: could not initialize proxy - no Session? 错误org.hibernate.LazyInitializationException - 无法初始化代理 - 没有会话 - ERROR org.hibernate.LazyInitializationException - could not initialize proxy - no Session org.hibernate.LazyInitializationException:无法初始化代理-无Session。 对于测试用例JUnit - org.hibernate.LazyInitializationException: could not initialize proxy - no Session . For a Testcase JUnit org.hibernate.LazyInitializationException:无法初始化代理-没有会话- - org.hibernate.LazyInitializationException: could not initialize proxy - no Session –
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM