【问题标题】:Spring CrudRepository throws org.hibernate.LazyInitializationExceptionSpring CrudRepository 抛出 org.hibernate.LazyInitializationException
【发布时间】:2012-07-02 12:47:51
【问题描述】:

我在使用 CrudRepository 时遇到了问题。示例:我有两个实体,实体 A 有一个实体 B 的集合。

class A {
  int id;
  int name;
  @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
  Set<B> bs;
  // getters and setters
}
class B {
  int id;
  int name;
  @ManyToOne(mappedBy="bs")
  A a;
  // getters and setters
}

然后我有 2 个存储库。

class ARepository extends CrudRepository<A, int>{}
class BRepository extends CrudRepository<B, int>{}

但是当我得到这个时,我得到了一个 org.hibernate.LazyInitializationException,我该如何避免这个?

@Service
@Transactional(readOnly=true)
class ServiceImpl implements Service {
@Resource ARepository ar;

@Override
A a = ar.findOne(int id);
}

这里是applicationContext.xml:

<jpa:repositories base-package="com.myproject.repository" />

<context:component-scan base-package="com.myproject.*" />
<context:annotation-config />

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager" >
    <property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="persistenceUnitName" value="keep-apm" />
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
            <property name="showSql" value="true" />
            <property name="generateDdl" value="true" />
            <property name="database" value="POSTGRESQL"/>
            <property name="databasePlatform" value="org.hibernate.dialect.PostgreSQLDialect"/>
        </bean>
    </property>
</bean>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="username" value="root" />
    <property name="password" value="root" />
    <property name="driverClassName" value="org.postgresql.Driver" />
    <property name="url" value="jdbc:postgresql://127.0.0.1:5432/db" />
</bean>
<bean id="sessionFactory" factory-bean="entityManagerFactory" factory-method="getSessionFactory">
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />

这里是 web.xml

<filter>
    <filter-name>openSessionInViewFilter</filter-name>
    <filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>
    <init-param>
        <param-name>singleSession</param-name>
        <param-value>true</param-value>
    </init-param>

</filter>
<filter-mapping>
    <filter-name>openSessionInViewFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
<filter>
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<listener>
    <listener-class>com.myproject.util.LogLocator</listener-class>
</listener>

<welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
</welcome-file-list>

a.bs(集合)不会被加载,总是抛出一个org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: no session or session was closed

提前谢谢你!!

【问题讨论】:

    标签: spring spring-data


    【解决方案1】:

    你需要使用启动一个事务,最好是通过Spring的Declarative Transaction Management

    在大多数情况下:

    • 在您的 XML 中定义一个 TransactionManager
    • 将此添加到您的 XML &lt;tx:annotation-driven /&gt;
    • @Transactional注释你的服务方法

    您可以在 Using @Transactional 部分找到示例设置

    【讨论】:

    • 嗨,肖恩,感谢您回答我,但我已经完成了一切。我只是添加了更多细节。请帮我解决这个问题。
    【解决方案2】:

    解决办法如下:

    我无法访问我的 web 层上的对象,我应该访问服务层中的延迟加载对象,它应该在一个事务中。

    【讨论】:

    • 您必须能够通过使用openSessionInViewFilter 访问web 视图 中延迟加载的对象,因为它会保持会话打开,直到请求完全完成。此外,您不应该使用singleSession=true。它会导致问题(但是它不会为整个请求提供一级缓存)。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-12-16
    • 2014-10-20
    • 1970-01-01
    • 1970-01-01
    • 2018-03-02
    • 2016-09-11
    • 2014-12-30
    相关资源
    最近更新 更多