懒加懒加载问题的解决方案

简介: 懒加载问题的解决方案

   在做项目的时候,一不小心就碰到懒加载的问题,今天做个总结(springdata-jpa):


/

Exception occurred during processing request: org.hibernate.LazyInitializationException: 
    failed to lazily initialize a collection of role: cn.itcast.bos.domain.base.Courier.fixedAreas,
    could not initialize proxy - no Session
    org.apache.struts2.json.JSONException: org.hibernate.LazyInitializationException: 
    failed to lazily initialize a collection of role: cn.itcast.bos.domain.base.Courier.fixedAreas, 
    could not initialize proxy - no Session

     

   第一种解决方案(不想要关联的集合对象):在getFixedAreas方法上加上

@JSON(serialize = false)
        @JSON(serialize = false)
    public Set<FixedArea> getFixedAreas() {
        return fixedAreas;
    }

   只要加上了@JSON(serialize = false),返回的数据格式里不会含有fixedAreas字段及数据,

   可以理解为过滤掉了fixedAreas数据

 

   第二种解决方案(想要关联的集合对象):在web.xml中配置,延长EntityManager的生命周期,类似Hibernate里面延长Sesseion的生命周期

 

<filter>
        <filter-name>OpenEntityManagerInView</filter-name>
        <filter-class>org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>OpenEntityManagerInView</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

   第三种解决方案(想要关联的集合对象):不配置OpenEntityManagerInViewFilter,不配置@JSON(serialize = false),设置为立即加载

   @ManyToMany(mappedBy = "couriers",fetch=FetchType.EAGER)

   private Set<FixedArea> fixedAreas = new HashSet<>();

   此时,返回的数据格式里有fixedAreas字段及数据

   获取A对象时,A对象关联B对象,FetchType默认是立即加载

   获取A对象时,A对象关联B对象的集合,FetchType默认是懒加载

 

   总结:不管是Hibernate还是JPA,有加载策略的问题,都是基于性能的考虑


相关文章
|
1月前
|
API 开发者
懒加载的实现
懒加载的实现
183 57
|
2月前
|
前端开发 JavaScript
3分钟掌握!用HTML+CSS实现懒加载,真的这么简单?
3分钟掌握!用HTML+CSS实现懒加载,真的这么简单?
|
2月前
|
前端开发 UED 开发者
React.lazy()与Suspense:实现按需加载的动态组件——深入理解代码分割、提升首屏速度和优化用户体验的关键技术
【8月更文挑战第31天】在现代Web应用中,性能优化至关重要,特别是减少首屏加载时间和提升用户交互体验。React.lazy()和Suspense组件提供了一种优雅的解决方案,允许按需加载组件,仅在需要渲染时加载相应代码块,从而加快页面展示速度。Suspense组件在组件加载期间显示备选内容,确保了平滑的加载过渡。
98 0
|
2月前
|
JavaScript API
如何实现图片懒加载
如何实现图片懒加载
64 0
|
5月前
|
JavaScript 前端开发
如何实现网页的懒加载?图片懒加载的原理
如何实现网页的懒加载?图片懒加载的原理
46 0
|
5月前
|
前端开发 JavaScript API
|
5月前
|
缓存 前端开发 JavaScript
加速你的网站:一文看懂预加载和懒加载
加速你的网站:一文看懂预加载和懒加载
|
编解码 前端开发 UED
响应式图片加载和优化策略
响应式图片加载和优化策略
153 0
|
数据采集 搜索推荐 UED
实现懒加载
懒加载是一种非常 useful 的技术,可以极大提高用户体验和网页性能,但也有一定的弊端,需要权衡选择。一般来说,对于加载的数据较多,页面性能和流量较为关注的场景,懒加载是一个不错的方案。但如果对 SEO 优化要求较高,或者加载的数据较少,也可以不使用懒加载
68 0