Spring JPA 错题集解决案例

 更新时间:2023年04月26日 11:34:00   作者:烟雨戏江南  
这篇文章主要为大家介绍了Spring JPA 错题集解决案例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一、No serializer found for class org.hibernate.proxy.pojo.bytebuddy.ByteBuddyInterceptor

详细报错

com.fasterxml.jackson.databind.exc.InvalidDefinitionException: No serializer found for class org.hibernate.proxy.pojo.bytebuddy.ByteBuddyInterceptor and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS) (through reference chain: com.example.sbjdemo.pojo.User["car"]->com.example.sbjdemo.pojo.Car$HibernateProxy$CCqaurKR["hibernateLazyInitializer"])
	at com.fasterxml.jackson.databind.exc.InvalidDefinitionException.from(InvalidDefinitionException.java:77) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.SerializerProvider.reportBadDefinition(SerializerProvider.java:1300) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.DatabindContext.reportBadDefinition(DatabindContext.java:400) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.ser.impl.UnknownSerializer.failForEmpty(UnknownSerializer.java:46) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.ser.impl.UnknownSerializer.serialize(UnknownSerializer.java:29) ~[jackson-databind-2.13.5.jar:2.13.5]
	at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:728) ~[jackson-databind-2.13.5.jar:2.13.5]
...........

触发场景

当fetch设置为懒加载的时候(fetch = FetchType.LAZY),进行查询操作

错误原因

car在转化为json的时候,序列化失败了(大概就是这个意思吧)

解决办法

在序列化失败的实体类上添加 @JsonIgnoreProperties(value = {"hibernateLazyInitializer"})

二、java.lang.StackOverflowError: null

详细报错

java.lang.StackOverflowError: null
	at java.lang.ClassLoader.defineClass1(Native Method) ~[na:1.8.0_212]
	at java.lang.ClassLoader.defineClass(ClassLoader.java:763) ~[na:1.8.0_212]
	at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) ~[na:1.8.0_212]
	at java.net.URLClassLoader.defineClass(URLClassLoader.java:468) ~[na:1.8.0_212]
	at java.net.URLClassLoader.access$100(URLClassLoader.java:74) ~[na:1.8.0_212]
	at java.net.URLClassLoader$1.run(URLClassLoader.java:369) ~[na:1.8.0_212]
	at java.net.URLClassLoader$1.run(URLClassLoader.java:363) ~[na:1.8.0_212]
	at java.security.AccessController.doPrivileged(Native Method) ~[na:1.8.0_212]

触发场景

两个关联的实体类都有外键字段,且都有关联注解,如:@OneToOne、@OneToManay、@ManyToOne、@ManyToMany

错误原因

两个相关联的对象互相调用并打印,形成一个递归调用,最后堆栈溢出

解决办法

两个关联的实体中的关联对象上,都加上一个 @JsonIgnore 注解,表示在序列化的时候,忽略这个属性(网上有说@ToString(exclude={"userList"})可以规避,但是我没有测试成功,大家可以自己试一下) 如下图所示

@OneToOne
@JoinColumn(name = "car_id")
@JsonIgnore
private Car car;

三、No class com.example.sbjdemo.pojo.User entity with id 18 exists!

详细报错

org.springframework.dao.EmptyResultDataAccessException: No class com.example.sbjdemo.pojo.User entity with id 18 exists!
	at org.springframework.data.jpa.repository.support.SimpleJpaRepository.lambda$deleteById$0(SimpleJpaRepository.java:173) ~[spring-data-jpa-2.7.10.jar:2.7.10]
	at java.util.Optional.orElseThrow(Optional.java:290) ~[na:1.8.0_212]
	at org.springframework.data.jpa.repository.support.SimpleJpaRepository.deleteById(SimpleJpaRepository.java:172) ~[spring-data-jpa-2.7.10.jar:2.7.10]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_212]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_212]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_212]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_212]
	at org.springframework.data.repository.core.support.RepositoryMethodInvoker$RepositoryFragmentMethodInvoker.lambda$new$0(RepositoryMethodInvoker.java:289) ~[spring-data-commons-2.7.10.jar:2.7.10]
	at org.springframework.data.repository.core.support.RepositoryMethodInvoker.doInvoke(RepositoryMethodInvoker.java:137) ~[spring-data-commons-2.7.10.jar:2.7.10]
	at org.springframework.data.repository.core.support.RepositoryMethodInvoker.invoke(RepositoryMethodInvoker.java:121) ~[spring-data-commons-2.7.10.jar:2.7.10]
	at org.springframework.data.repository.core.support.RepositoryComposition$RepositoryFragments.invoke(RepositoryComposition.java:530) ~[spring-data-commons-2.7.10.jar:2.7.10]

触发场景

执行数据删除操作

错误原因

删除的数据在数据库中不存在

以上就是Spring JPA 错题集解决案例的详细内容,更多关于Spring JPA 错题集的资料请关注脚本之家其它相关文章!

相关文章

  • SpringBoot集成单点登录CAS的方法实现

    SpringBoot集成单点登录CAS的方法实现

    本文主要介绍了SpringBoot集成单点登录CAS的方法实现,包括CAS的基本概念、集成步骤、具体代码示例等,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2024-03-03
  • 老生常谈比较排序之堆排序

    老生常谈比较排序之堆排序

    下面小编就为大家带来一篇老生常谈比较排序之堆排序。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 详解JAVA8 函数式接口

    详解JAVA8 函数式接口

    这篇文章主要介绍了JAVA8 函数式接口的相关资料,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • SpringBoot启动失败的原因及其解决方法

    SpringBoot启动失败的原因及其解决方法

    对于springboot的启动失败,相信大家都有经历,但是为什么会启动失败,以及怎么解决都只能通过日志进行查看,在这里,我会将常见的springboot启动失败的报错一一展示,需要的朋友可以参考下
    2024-06-06
  • Java判断当前日期是周几的方法汇总

    Java判断当前日期是周几的方法汇总

    在Java编程中,我们经常会遇到需要获取当前日期是周几的需求。根据国际惯例,一周通常是从周一开始,到周日结束,记作1至7,本文将介绍几种常用的Java方法,让你能够准确地判断当前日期是周几,感兴趣的朋友一起看看吧
    2024-03-03
  • 解决mybatis使用foreach批量insert异常的问题

    解决mybatis使用foreach批量insert异常的问题

    这篇文章主要介绍了解决mybatis使用foreach批量insert异常的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 浅析java 的 static 关键字用法

    浅析java 的 static 关键字用法

    这篇文章主要介绍了浅析java 的 static 关键字用法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-06-06
  • 使用IntelliJ IDEA 进行代码对比的方法(两种方法)

    使用IntelliJ IDEA 进行代码对比的方法(两种方法)

    这篇文章给大家带来了两种IntelliJ IDEA 进行代码对比的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Java Spring循环依赖原理与bean的生命周期图文案例详解

    Java Spring循环依赖原理与bean的生命周期图文案例详解

    这篇文章主要介绍了Spring循环依赖原理与bean的生命周期图文案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • 解决mybatis-generator生成Mapper文件没有Selective结尾的问题

    解决mybatis-generator生成Mapper文件没有Selective结尾的问题

    这篇文章主要介绍了解决mybatis-generator生成Mapper文件没有Selective结尾的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09

最新评论