Spring Data Jpa懒加载报错分析

简介: Spring Data Jpa懒加载报错分析

1 Jpa懒加载报错

Caused by: org.apache.tapestry5.runtime.ComponentEventException: could not initialize proxy - no Session

2 报错分析

异常很明确,没有session,那没有session和我们的懒加载和立即加载有什么联系呢?我想大部分的小伙伴都遇到过这个问题,也都能说出答案。

  1. 立即加载,他是无论用不用到关联实体,都会将关联实体查出来,这个挺简单的,也不会引发啥异常,但是性能就有点可悲了,因为他啥都能查出来,就像for循环一样,如果不考虑性能,基本没有for循环搞定不了的事。

     @ManyToOne(fetch = FetchType.EAGER)
     @JoinColumn(name = "tradeRuleId", referencedColumnName = "id", insertable = false, updatable = false)
     private TradeRule tradeRule;
  2. 懒加载,首先懒加载是在查询数据时不会将关联实体直接查出来,而是用的时候查出来。

    @OneToMany(fetch = FetchType.LAZY)
    @JoinColumn(name = "sailingScheduleId", referencedColumnName = "id", insertable = false, updatable = false)
    private Set<Dynamic> dynamics;

    如果我使用了懒加载,然后我又要从懒加载的实体上获得其内部属性这会产生什么后果。这就是上面的结果,抛出了异常

    Caused by: org.apache.tapestry5.runtime.ComponentEventException: could not initialize proxy - no Session

    那为什么是没有session呢,那是因为懒加载必须要有session连接才能获得数据,如果session没有,那就回报错,这下应该很明了了。在使用查询的时候,会获取数据库的连接session,查询后session关闭,但是懒加载的属性并没有在查询的时候查出来,所以读取他的时候就会报错,因为session已经关闭了。

    那为什么立即加载就没问题,因为立即加载是查询一次之后,框架会把数据存储在内存中,所以立即加载就不用考虑了。

    那又有一个问题,什么叫懒加载在用的时候会去查询?这个问题,我是很疑惑的,后来得到了一个解答。

    List<Node> nodeList = ApplicationContextUtil.instance.getJpaUtil().list(                "select u.nodeSet from simm.spring.entity.ProcessBlock u where u.id=1", null, Node.class);
    

    以上就是用的时候去查询,也就是针对这个懒加载的实体单独的一个查询。

3 Session

这里面说的是数据库的session,下面说一说的他的运用

比如 Mybatics 的SqlSessionFactory都是拿到session才能去查数据,通透点说就是要登录数据库系统才行,我看网上有的说在service层session是共享的,搞得我去session层去取懒加载的数据,结果还是报错,回头想想这种说法就是错误的,每次查询都说开启一个session然后session在查询后会断开。谈什么service层数据库session共享呢?

相关文章
|
29天前
|
NoSQL Java 数据库连接
《深入理解Spring》Spring Data——数据访问的统一抽象与极致简化
Spring Data通过Repository抽象和方法名派生查询,简化数据访问层开发,告别冗余CRUD代码。支持JPA、MongoDB、Redis等多种存储,统一编程模型,提升开发效率与架构灵活性,是Java开发者必备利器。(238字)
|
1月前
|
存储 Java 关系型数据库
Spring Boot中Spring Data JPA的常用注解
Spring Data JPA通过注解简化数据库操作,实现实体与表的映射。常用注解包括:`@Entity`、`@Table`定义表结构;`@Id`、`@GeneratedValue`配置主键策略;`@Column`、`@Transient`控制字段映射;`@OneToOne`、`@OneToMany`等处理关联关系;`@Enumerated`、`@NamedQuery`支持枚举与命名查询。合理使用可提升开发效率与代码可维护性。(238字)
260 1
存储 JSON Java
442 0
|
2月前
|
SQL Java 数据库连接
Spring Data JPA 技术深度解析与应用指南
本文档全面介绍 Spring Data JPA 的核心概念、技术原理和实际应用。作为 Spring 生态系统中数据访问层的关键组件,Spring Data JPA 极大简化了 Java 持久层开发。本文将深入探讨其架构设计、核心接口、查询派生机制、事务管理以及与 Spring 框架的集成方式,并通过实际示例展示如何高效地使用这一技术。本文档约1500字,适合有一定 Spring 和 JPA 基础的开发者阅读。
283 0
|
4月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
307 0
|
4月前
|
NoSQL Java Redis
Redis基本数据类型及Spring Data Redis应用
Redis 是开源高性能键值对数据库,支持 String、Hash、List、Set、Sorted Set 等数据结构,适用于缓存、消息队列、排行榜等场景。具备高性能、原子操作及丰富功能,是分布式系统核心组件。
525 2
|
5月前
|
Java API 数据库
JPA简介:Spring Boot环境下的实践指南
上述内容仅是JPA在Spring Boot环境下使用的冰山一角,实际的实践中你会发现更深更广的应用。总而言之,只要掌握了JPA的规则,你就可以借助Spring Boot无比丰富的功能,娴熟地驾驶这台高性能的跑车,在属于你的程序世界里驰骋。
198 15
|
5月前
|
负载均衡 Java API
基于 Spring Cloud 的微服务架构分析
Spring Cloud 是一个基于 Spring Boot 的微服务框架,提供全套分布式系统解决方案。它整合了 Netflix、Zookeeper 等成熟技术,通过简化配置和开发流程,支持服务发现(Eureka)、负载均衡(Ribbon)、断路器(Hystrix)、API网关(Zuul)、配置管理(Config)等功能。此外,Spring Cloud 还兼容 Nacos、Consul、Etcd 等注册中心,满足不同场景需求。其核心组件如 Feign 和 Stream,进一步增强了服务调用与消息处理能力,为开发者提供了一站式微服务开发工具包。
583 0
|
6月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
228 32
|
7月前
|
NoSQL 安全 Java
深入理解 RedisConnectionFactory:Spring Data Redis 的核心组件
在 Spring Data Redis 中,`RedisConnectionFactory` 是核心组件,负责创建和管理与 Redis 的连接。它支持单机、集群及哨兵等多种模式,为上层组件(如 `RedisTemplate`)提供连接抽象。Spring 提供了 Lettuce 和 Jedis 两种主要实现,其中 Lettuce 因其线程安全和高性能特性被广泛推荐。通过手动配置或 Spring Boot 自动化配置,开发者可轻松集成 Redis,提升应用性能与扩展性。本文深入解析其作用、实现方式及常见问题解决方法,助你高效使用 Redis。
740 4